我有以下代码使用 Titan 创建图形数据库:
public class TitanMassiveInsertion {
private TitanGraph titanGraph = null;
private BatchGraph<TitanGraph> batchGraph = null;
public static void main(String args[]) {
TitanMassiveInsertion test = new TitanMassiveInsertion();
test.startup("data/titanDB");
test.createGraph("data/flickrEdges.txt");
test.shutdown();
}
public void startup(String titanDBDir) {
System.out.println("The Titan database is now starting . . . .");
BaseConfiguration config = new BaseConfiguration();
Configuration storage = config.subset(GraphDatabaseConfiguration.STORAGE_NAMESPACE);
storage.setProperty(GraphDatabaseConfiguration.STORAGE_BACKEND_KEY, "local");
storage.setProperty(GraphDatabaseConfiguration.STORAGE_DIRECTORY_KEY, titanDBDir);
storage.setProperty(GraphDatabaseConfiguration.STORAGE_BATCH_KEY, true);
Configuration index = storage.subset(GraphDatabaseConfiguration.INDEX_NAMESPACE).subset("nodes");
index.setProperty(INDEX_BACKEND_KEY, "elasticsearch");
index.setProperty("local-mode", true);
index.setProperty("client-only", false);
index.setProperty(STORAGE_DIRECTORY_KEY, titanDBDir + File.separator + "es");
titanGraph = TitanFactory.open(config);
titanGraph.makeKey("nodeId").dataType(String.class).indexed(Vertex.class).make();
titanGraph.makeLabel("similar").oneToOne().make();
titanGraph.commit();
batchGraph = new BatchGraph<TitanGraph>(titanGraph, VertexIDType.STRING, 1000);
batchGraph.setVertexIdKey("nodeId");
batchGraph.setLoadingFromScratch(true);
}
public void shutdown() {
System.out.println("The Titan database is now shuting down . . . .");
if(titanGraph != null) {
batchGraph.shutdown();
titanGraph.shutdown();
batchGraph = null;
titanGraph = null;
}
}
public void createGraph(String datasetDir) {
System.out.println("Creating the Titan database . . . .");
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(datasetDir)));
String line;
int lineCounter = 1;
int nodeCounter = 0;
Vertex srcVertex, dstVertex;
while((line = reader.readLine()) != null) {
if(lineCounter > 4) {
String[] parts = line.split("\t");
srcVertex = batchGraph.getVertex(parts[0]);
if(srcVertex == null) {
srcVertex = batchGraph.addVertex(parts[0]);
srcVertex.setProperty("nodeId", parts[0]);
nodeCounter++;
}
dstVertex = batchGraph.getVertex(parts[1]);
if(dstVertex == null) {
dstVertex = batchGraph.addVertex(parts[1]);
dstVertex.setProperty("nodeId", parts[1]);
nodeCounter++;
}
Edge edge = batchGraph.addEdge(null, srcVertex, dstVertex, "similar");
//System.out.println(edge);
System.out.println(nodeCounter);
}
lineCounter++;
}
reader.close();
}
catch(IOException ioe) {
ioe.printStackTrace();
}
}
}
创建图形数据库后,我想测试我的代码以查看一切正常,因此我尝试使用此测试代码打印顶点:
TitanGraph graph = TitanFactory.open("data/titanDB");
for(Vertex v : graph.getVertices()) {
System.out.println(v.getProperty("nodeId"));
}
graph.shutdown();
但它什么也没打印,而且似乎在无限循环中堆叠。正如教程建议的那样,我也尝试过
Vertex v : graph.query().vertices()
,但问题存在。另一方面,当System.out.println(graph.getVertices("nodeId", "2604051056"));
我得到正确的输出时。getVertices() 函数有问题吗?