0

我使用以下代码成功合并节点:

session = cypher.Session('http://192.168.56.20:7474/db/data/')
txa = session.create_transaction()
txa.append("""
  MERGE (frame:FRAME {timestamp:{props}.ts})
  ON CREATE SET frame:FIRST_FRAME
  RETURN frame
""", props)
txa.commit()
result, = txa.commit()
frame, = result[0]

日志文件如下所示:

INFO:py2neo.packages.httpstream.http:>>> POST http://192.168.56.20:7474/db/data/transaction/commit [910]
DEBUG:py2neo.packages.httpstream.http:>>> Host: 192.168.56.20:7474
DEBUG:py2neo.packages.httpstream.http:>>> Content-Type: application/json
DEBUG:py2neo.packages.httpstream.http:>>> X-Stream: true;format=pretty
DEBUG:py2neo.packages.httpstream.http:>>> User-Agent: py2neo/1.6.1 HTTPStream/1.1.0          Python/2.7.5-final-0 (darwin)
INFO:py2neo.packages.httpstream.http:<<< 200 OK [chunked]
DEBUG:py2neo.packages.httpstream.http:<<< transfer-encoding: chunked
DEBUG:py2neo.packages.httpstream.http:<<< access-control-allow-origin: *
DEBUG:py2neo.packages.httpstream.http:<<< server: Jetty(9.0.5.v20130815)
DEBUG:py2neo.packages.httpstream.http:<<< content-type: application/json
DEBUG:py2neo.packages.httpstream.http:<<< content-encoding: UTF-8

返回的结果变量是:

[Record(columns=(u'frame',), values=(Node('http://0.0.0.0:7474/db/data/node/24'),))]

注意错误的 uri (0.0.0.0)

当我尝试使用返回的节点实例时,会引发连接异常。IE:

frame.remove_labels('FIRST_FRAME')

py2neo.packages.httpstream.http.SocketError: Connection refused

通过记录的跟踪,我可以看到它试图从错误的服务器获取数据:

INFO:py2neo.packages.httpstream.http:>>> GET http://0.0.0.0:7474/db/data/node/24/properties

我究竟做错了什么?

4

2 回答 2

2

这肯定是一个奇怪的反应——我假设你没有在代码中的任何地方使用重写函数?如果是这样,请检查其配置,如果不是,您可以尝试其他一些方法:

  1. 你的服务器前面有一层作为代理吗?这通常用于应用身份验证或类似操作。如果是这样,请尝试绕过它并直接访问服务器,看看您是否仍然遇到问题。
  2. 尝试从命令行使用 cURL 执行相同的请求以查看原始响应。这可以帮助确认 0.0.0.0 在什么级别被替换。
于 2014-01-17T09:21:30.330 回答
0

我遇到了同样的问题,结果证明是由于 Neo4j 服务器配置。

http://docs.neo4j.org/chunked/stable/server-configuration.html

我有:

#allow any client to connect
org.neo4j.server.webserver.address=0.0.0.0

这需要是您从 Py2Neo 使用的实际 IP 地址:

#allow any client to connect
org.neo4j.server.webserver.address=real-ip-here (192.168.56.20 in your example)
于 2014-09-30T03:59:08.447 回答