我有一个使用Cassandra的小型Rexster / Titan集群。 Rexster扩展用于查询图形。我做了一些基准测试,并且多次开始和停止Rexster / Titan。但现在我遇到了一个奇怪的问题:Rexster拒绝启动但没有显示任何错误消息。
我试图找出造成这种情况的原因,并将群集缩减为单个节点192.168.0.4
。
如果我删除了我的扩展程序,Rexster会设法启动。
# console output
Forking Cassandra...
Running `nodetool statusthrift`..... OK
(returned exit status 0 and printed string "running").
Forking Titan + Rexster...
Connecting to Titan + Rexster (127.0.0.1:8184)...... OK
(connected to 127.0.0.1:8184).
Run rexster-console.sh to connect.
但是当我将我的扩展程序uber JAR放在ext
文件夹中时,Rexster拒绝启动。
# console output
Forking Cassandra...
Running `nodetool statusthrift`..... OK
(returned exit status 0 and printed string "running").
Forking Titan + Rexster...
Connecting to Titan + Rexster (127.0.0.1:8184)............................
timeout exceeded (60 seconds): could not connect to 127.0.0.1:8184
See /var/lib/titan/bin/../log/rexstitan.log for Rexster log output.
如果我现在按照控制台输出的建议检查rexstitan.log
,我找不到任何错误消息。
# rexstitan.log
0 [main] INFO com.tinkerpop.rexster.Application - .:Welcome to Rexster:.
73 [main] INFO com.tinkerpop.rexster.server.RexsterProperties -
Using [/var/lib/titan/rexhome/../conf/rexster-cassandra-cluster.xml]
as configuration source.
78 [main] INFO com.tinkerpop.rexster.Application - Rexster is watching
[/var/lib/titan/rexhome/../conf/rexster-cassandra-cluster.xml] for change.
244 [main] INFO com.netflix.astyanax.connectionpool.impl.ConnectionPoolMBeanManager -
Registering mbean: com.netflix.MonitoredResources:type=ASTYANAX,
name=ClusterTitanConnectionPool,ServiceType=connectionpool
252 [main] INFO com.netflix.astyanax.connectionpool.impl.CountingConnectionPoolMonitor -
AddHost: 192.168.0.4
537 [main] INFO com.netflix.astyanax.connectionpool.impl.ConnectionPoolMBeanManager -
Registering mbean: com.netflix.MonitoredResources:type=ASTYANAX,
name=KeyspaceTitanConnectionPool,ServiceType=connectionpool
538 [main] INFO com.netflix.astyanax.connectionpool.impl.CountingConnectionPoolMonitor -
AddHost: 192.168.0.4
1951 [main] INFO com.thinkaurelius.titan.graphdb.configuration.GraphDatabaseConfiguration -
Set cluster.partition=false from store features
1971 [main] INFO com.thinkaurelius.titan.graphdb.configuration.GraphDatabaseConfiguration -
Set default timestamp provider MICRO
2019 [main] INFO com.thinkaurelius.titan.graphdb.configuration.GraphDatabaseConfiguration -
Generated unique-instance-id=7f0000012902-node1
2045 [main] INFO com.netflix.astyanax.connectionpool.impl.ConnectionPoolMBeanManager -
Registering mbean: com.netflix.MonitoredResources:type=ASTYANAX,
name=ClusterTitanConnectionPool,ServiceType=connectionpool
2046 [main] INFO com.netflix.astyanax.connectionpool.impl.CountingConnectionPoolMonitor -
AddHost: 192.168.0.4
2053 [main] INFO com.netflix.astyanax.connectionpool.impl.ConnectionPoolMBeanManager -
Registering mbean: com.netflix.MonitoredResources:type=ASTYANAX,
name=KeyspaceTitanConnectionPool,ServiceType=connectionpool
2054 [main] INFO com.netflix.astyanax.connectionpool.impl.CountingConnectionPoolMonitor -
AddHost: 192.168.0.4
2228 [main] INFO com.thinkaurelius.titan.diskstorage.Backend -
Initiated backend operations thread pool of size 4
6619 [main] INFO com.thinkaurelius.titan.diskstorage.log.kcvs.KCVSLog -
Loaded unidentified ReadMarker start time Timepoint[1423479705116000 μs]
into com.thinkaurelius.titan.diskstorage.log.kcvs.KCVSLog$MessagePuller@212f3ff1
6625 [main] INFO com.tinkerpop.rexster.RexsterApplicationGraph -
Graph [graph] - configured with allowable namespace [*:*]
对我来说唯一看起来很奇怪的条目是关于日志的条目:
6619 [main] INFO com.thinkaurelius.titan.diskstorage.log.kcvs.KCVSLog -
Loaded unidentified ReadMarker start time Timepoint[1423479705116000 μs]
into com.thinkaurelius.titan.diskstorage.log.kcvs.KCVSLog$MessagePuller@212f3ff1
我的异常使用记录器进行调试。您可以在github上看到实例化用法:https://github.com/sebschlicht/titan-graphity-kribble/blob/master/src/main/java/de/uniko/sebschlicht/titan/extensions/GraphityExtension.java#L22
虽然Rexster无法启动,但是在控制台中显示PID但是curl
无法连接到Rexster:
$ curl 192.168.0.4:8182
curl: (7) Failed to connect to 192.168.0.4 port 8182: Connection refused
为什么雷克斯特没有抛出异常?我该如何调试这种情况?
修改: 我删除了代码中的所有日志消息。我删除了启动期间可能抛出的所有异常。仍然Rexster拒绝从我的扩展开始,日志文件中唯一的提示是未识别的读取标记。我必须弄清楚是什么阻止了Rexster的启动。
答案 0 :(得分:0)
日志消息无需担心。 在另一个项目中重建应用程序后,Rexster现在可以从扩展开始了。在重建期间,我注意到两种情况,可能导致所描述的行为:
如果您的项目依赖于第二个项目,您可以使用Maven将其作为依赖项注入。但是,如果您使用
mvn clean package
构建扩展的JAR文件,默认情况下它不包含此依赖项。您需要使用Maven插件(例如maven-shade-plugin
)来创建包含扩展所需的所有依赖项的着色JAR。对于所有与Titan / Rexster / Blueprints相关的依赖关系,将依赖范围设置为provided
。使用着色的uber-JAR将扩展部署到Rexster。
然而,这对我来说并不陌生,不应该在我的案例中造成问题。可能有更多情况导致此问题,或者Maven的问题可能会混淆阴影JAR。随意浏览commit on github来捕捉这个伏都教。
此行为的另一个原因是缺少扩展名。
如果您在com.tinkerpop.rexster.extension.RexsterExtension
资源文件中指定了一个扩展,但在启动时不存在,Rexster既不记录也不抛出异常,但拒绝启动。