JanusGraph多圖配置目的 :一個端口開啟后可根據句柄操作多個圖 。(cassandra存儲后端)
1、GremlinServer多圖配置
服務器gremlin-server.yaml中可以設置多個graph的properties文件 ,建議先拷貝gremlin-server.yaml改個名字,這里我用了一個新拷貝的文件來配置多圖:
[root@tdh01 gremlin-server]# pwd /usr/Programe_files/JanusGraph/janusgraph-0.3.2/conf/gremlin-server [root@tdh01 gremlin-server]# cp gremlin-server.yaml socket-gremlin-server-graph2.yaml [root@tdh01 gremlin-server]# vim socket-gremlin-server-graph2.yaml ### 下圖內容: 15 host: 192.168.…… 16 port: 8182 17 scriptEvaluationTimeout: 30000 18 channelizer: org.apache.tinkerpop.gremlin.server.channel.WsAndHttpChannelizer 19 graphs: { 20 graph: conf/gremlin-server/socket-janusgraph-cassandra-server.properties, 21 graph_test: conf/gremlin-server/socket-test1028-janusgraph-cassandra-server.properties 22 }
這里我建立了兩個圖,graph和graph_test兩個圖分別使用了不同的配置文件,同一個后端,這兩個socket-……文件分別是從conf/janusgraph-cassandra.properties 中拷貝下來改名后的配置文件。
2.配置keyspace和index-name,使用多圖分開存儲
socket-test1028-janusgraph-cassandra-server.properties 中需要聲明keyspace和index-name,否則會按照默認名字janusgraph建立存儲和索引。多個properties指向同一個圖。
storage.cassandra.keyspace=test_cassandra index.test_cassandra.index-name=test_cassandra
3.scripts/empty-sample.groovy,增加traversalSource,對應不同的graph
[root@tdh01 scripts]# pwd /usr/Programe_files/JanusGraph/janusgraph-0.3.2/scripts [root@tdh01 scripts]# vim empty-sample.groovy ### 下圖文件內容:graph_test是自己配置的另一個多圖名稱 globals << [g : graph.traversal(), t : graph_test.traversal()]
4.多圖模式的開啟:
# socket-gremlin-server-graph2.yaml是自己一開始配的gremlin-server.yaml的拷貝;
bin/gremlin-server.sh ./conf/gremlin-server/socket-gremlin-server-graph2.yaml
開啟成功會有兩個圖的實例創建成功,看到下面的結果說明多圖配置成功了。
5.多圖模式操作:
# 連接之后更具句柄操作:
gremlin> :remote connect tinkerpop.server conf/remote.yaml
6.新的圖存儲位置
參考文章:
JanusGraph集群搭建,多圖配置及索引---組建集群及多圖(http://www.itboth.com/d/YVvEja6jueA3/janusgraph-cassandra)
JanusGraph服務同時支持WebSocket和HTTP:https://blog.csdn.net/ZYC88888/article/details/86605696
JanusGraph 存儲后端之 HBase 安裝配置:https://www.daimafans.com/article/d5439306080452608-p1-o1.html
Apache HBase™參考指南:https://hbase.apache.org/book.html#quickstart