如何解决Gremlin docker 服务器连接不起作用
我正在使用官方 docker 容器运行 gremlin 服务器:
docker run --rm -it -p 8182:8182 --name gremlin tinkerpop/gremlin-server
然后我尝试从主机运行以下脚本:
from gremlin_python.process.anonymous_traversal import traversal
from gremlin_python.driver.driver_remote_connection import DriverRemoteConnection
if __name__ == "__main__":
g = traversal().withRemote(DriverRemoteConnection('ws://localhost:8182','g'))
g.V().drop()
g.V().addV('person')
l = g.V().hasLabel('person')
print(l.toList())
连接似乎有效(没有错误),但查询似乎并未真正执行(gremlin 服务器统计数据显示没有任何调用)。
更奇怪的部分是 toList()
调用阻塞了执行,并且什么都不返回。如果然后我停止docker容器,python端的连接就会下降。
我使用的是 gremlin 服务器的默认设置。 有人能帮我了解发生了什么吗?
编辑:我也尝试将 gremlin 配置主机更改为 0.0.0.0。
编辑:所以看起来只有 toList
等待答案的原因是因为其他查询实际上尚未执行,您需要 .next()
。
解决方法
事实证明有两个错误:
- 地址必须以
/gremlin
结尾,所以在我的例子中是'ws://localhost:8182/gremlin'
- 尝试此操作时,会出现一个异常,起初看起来像是连接错误:
RuntimeError: Event loop is closed
Exception ignored in: <function ClientResponse.__del__ at 0x7fb532031af0>
Traceback (most recent call last):
[..]
File "/usr/lib/python3.8/asyncio/selector_events.py",line 692,in close
File "/usr/lib/python3.8/asyncio/base_events.py",line 719,in call_soon
File "/usr/lib/python3.8/asyncio/base_events.py",line 508,in _check_closed
RuntimeError: Event loop is closed
这实际上不是连接错误,而是连接未正确关闭的警告。如果您进行调查,您会注意到查询实际上已执行。处理这个问题的正确方法是按照以下方式写一些东西:
conn = DriverRemoteConnection('ws://localhost:8182/gremlin','g')
g = traversal().withRemote(conn)
[do your graph operations]
conn.close()
有了这个,没有例外,生活是美好的。我很惊讶这没有出现在任何文档中。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。