【发布时间】:2014-10-06 20:41:32
【问题描述】:
我正在使用 GrapheneDB、Tornado、py2neo 在 Heroku 上运行应用程序。
我正在尝试使用 py2neo 的 Cypher 交易。
我可以在本地运行:
graphenedb_url = os.environ.get("GRAPHENEDB_URL", "http://localhost:7474/")
service_root = neo4j.ServiceRoot(URI(graphenedb_url).resolve("/"))
graph_db = service_root.graph_db
session = cypher.Session()
但是当我部署到 Heroku 时,我得到:
2014-10-06T20:33:34.626356+00:00 app[web.1]: File "main.py", line 33, in <module>
2014-10-06T20:33:34.626364+00:00 app[web.1]: session = cypher.Session()
2014-10-06T20:33:34.626367+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/cypher.py", line 127, in __init__
2014-10-06T20:33:34.626435+00:00 app[web.1]: self._graph_db = self._service_root.graph_db
2014-10-06T20:33:34.626456+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/neo4j.py", line 462, in graph_db
2014-10-06T20:33:34.626550+00:00 app[web.1]: return GraphDatabaseService.get_instance(self.__metadata__["data"])
2014-10-06T20:33:34.626571+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/neo4j.py", line 338, in __metadata__
2014-10-06T20:33:34.626641+00:00 app[web.1]: self.refresh()
2014-10-06T20:33:34.626662+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/neo4j.py", line 360, in refresh
2014-10-06T20:33:34.626732+00:00 app[web.1]: self._metadata = ResourceMetadata(self._get().content)
2014-10-06T20:33:34.626756+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/neo4j.py", line 365, in _get
2014-10-06T20:33:34.626838+00:00 app[web.1]: product=self._product)
2014-10-06T20:33:34.626842+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/packages/httpstream/http.py", line 803, in get
2014-10-06T20:33:34.627276+00:00 app[web.1]: return rq.submit(redirect_limit=redirect_limit, **kwargs)
2014-10-06T20:33:34.627279+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/packages/httpstream/http.py", line 388, in submit
2014-10-06T20:33:34.627281+00:00 app[web.1]: http, rs = submit(self.method, uri, self.body, headers)
2014-10-06T20:33:34.627282+00:00 app[web.1]: File "/app/.heroku/python/lib/python2.7/site-packages/py2neo/packages/httpstream/http.py", line 328, in submit
2014-10-06T20:33:34.627288+00:00 app[web.1]: raise SocketError(code, description, host_port=uri.host_port)
2014-10-06T20:33:34.627290+00:00 app[web.1]: py2neo.packages.httpstream.http.SocketError: Connection refused
2014-10-06T20:33:34.626336+00:00 app[web.1]: Traceback (most recent call last):
2014-10-06T20:33:35.495790+00:00 heroku[web.1]: Process exited with status 1
2014-10-06T20:33:35.505975+00:00 heroku[web.1]: State changed from starting to crashed
我也试过了:
session = cypher.Session(URI(graphenedb_url).resolve("/"))
但这甚至在本地都行不通。我试过浏览 Graphene Docs,但没有运气。
有什么建议吗?
更新: 如果我这样做:
session = cypher.Session(os.environ.get("GRAPHENEDB_URL"))
tx = session.create_transaction()
tx.append("MATCH n RETURN n")
results = tx.execute()
for r in results[0]:
r.values[0]
我明白了:
Node('http://localhost:0/db/data/node/40')
Node('http://localhost:0/db/data/node/41')
Node('http://localhost:0/db/data/node/42')
我猜端口应该是 7474 而不是 0?
或者不应该是 Node('GRAPHENEDB_URI/db/data/node/40') 而不是 localhost?
【问题讨论】:
-
您确定指向 /db/data/ 端点吗?您的默认值应为“localhost:7474/db/data”,对于您的 GrapheneDB 网址也是如此。
-
所以我尝试了
cypher.Session(os.environ.get("GRAPHENEDB_URL"))并在执行后尝试通过事务循环后出现另一个错误:SocketError: Can't assign requested address让我尝试通过控制台查看是否有其他问题部分代码。 -
我是来自 GapheneDB 的 Alberto。您使用的是哪个版本的 Neo4j?您能否检查一下在没有交易的情况下是否也会发生这种情况?
-
嗨 Alberto,我有:
graph.neo4j_version > (2, 1, 3, u'')我能够执行批处理:我在日志中得到了200 OK和正确的 URI。 -
Alberto,经过进一步调查,我更新了我的问题。