Rexster拒绝以扩展名开始,但不显示错误

时间:2015-01-26 11:39:38

标签: cassandra titan rexster

我有一个使用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的启动。

1 个答案:

答案 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既不记录也不抛出异常,但拒绝启动。