- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 Python (2.7.6) 和 Py2Neo (1.6.4) 更新 Neo4j 服务器上的数据。我的加载函数是:
from py2neo import neo4j,node, rel, cypher
session = cypher.Session('http://my_neo4j_server.com.mine:7474')
def load_data():
tx = session.create_transaction()
for row in dataframe.iterrows(): #dataframe is a pandas dataframe
name = row[1].name
id = row[1].id
merge_query = "MERGE (a:label {name:'%s', name_var:'%s'}) " % (id, name)
tx.append(merge_query)
tx.commit()
当我在 Windows 中从 Spyder 执行它时,效果很好。 dataframe 中的所有数据都提交给 neo4j 并在图中可见。但是,当我从 linux 服务器(不同于 neo4j 服务器)运行它时,我在 tx.commit() 处收到以下错误。请注意,我有相同版本的 python 和 py2neo。
INFO:py2neo.packages.httpstream.http:>>> POST http://neo4j1.qs:7474/db/data/transaction/commit [1360120]
INFO:py2neo.packages.httpstream.http:<<< 200 OK [chunked]
ERROR:__main__:some part of process failed
Traceback (most recent call last):
File "my_file.py", line 132, in load_data
tx.commit()
File "/usr/local/lib/python2.7/site-packages/py2neo/cypher.py", line 242, in commit
return self._post(self._commit or self._begin_commit)
File "/usr/local/lib/python2.7/site-packages/py2neo/cypher.py", line 208, in _post
j = rs.json
File "/usr/local/lib/python2.7/site-packages/py2neo/packages/httpstream/http.py", line 563, in json
return json.loads(self.read().decode(self.encoding))
File "/usr/local/lib/python2.7/site-packages/py2neo/packages/httpstream/http.py", line 634, in read
data = self._response.read()
File "/usr/local/lib/python2.7/httplib.py", line 543, in read
return self._read_chunked(amt)
File "/usr/local/lib/python2.7/httplib.py", line 597, in _read_chunked
raise IncompleteRead(''.join(value))
IncompleteRead: IncompleteRead(128135 bytes read)
这篇文章 ( IncompleteRead using httplib ) 表明这是一个 httplib 错误。我不确定如何处理,因为我没有直接调用 httplib。
关于让此负载在 Linux 上运行的任何建议或 IncompleteRead 错误消息的含义是什么?
更新:IncompleteRead 错误是由返回的 Neo4j 错误引起的。 _read_chunked 中返回的导致错误的行是:
pe}"}]}],"errors":[{"code":"Neo.TransientError.Network.UnknownFailure"
Neo4j 文档说这是一个未知的网络错误。
最佳答案
虽然我不能肯定地说,但这意味着客户端和服务器之间存在某种本地网络问题,而不是库中的错误。 Py2neo 包装了 httplib(它本身非常可靠),并且从堆栈跟踪来看,它看起来好像客户端期望来自分块响应的更多 block 。
要进一步诊断,您可以从 Linux 应用程序服务器对数据库服务器进行一些 curl 调用,看看哪些成功了,哪些没有成功。如果可行,请尝试编写一个快速而肮脏的 python 脚本,以直接使用 httplib 进行相同的调用。
更新 1: 考虑到上述更新以及服务器流式传输其响应这一事实,我认为 block 大小可能代表预期的有效负载,但错误会缩短响应时间。使用 curl 重新创建问题似乎是最好的下一步,可以帮助确定它是驱动程序、服务器还是其他方面的故障。
更新 2:今天早上再次查看,我注意到您正在使用 Python 替换 MERGE 语句中的属性。作为一种好的做法,您应该在 Cypher 级别使用参数替换:
merge_query = "MERGE (a:label {name:{name}, name_var:{name_var}})"
merge_params = {"name": id, "name_var": name}
tx.append(merge_query, merge_params)
关于python - 如何使用 Py2Neo 修复 Linux 上的 IncompleteRead 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25252762/
我想编写一个程序来从 Twitter 获取推文,然后进行情感分析。我编写了以下代码,即使在导入所有必要的库后也出现错误。我对数据科学比较陌生,所以请帮助我。 我无法理解此错误的原因: class Tw
我正在使用 Tweepy 在 Python3 中编写一个 Twitter 流监听器。流式传输一段时间后出现此错误: urllib3.exceptions.ProtocolError: ('Connec
当我尝试使用 requests 下载一些图像时遇到了这个奇怪的错误,代码如下, import requests import StringIO r = requests.get(image_url,
这是一段网络挖掘脚本。 def printer(q,missing): while 1: tmpurl=q.get() try: ima
我正在尝试从网站获取一些数据。但是它返回给我incomplete read。我要获取的数据是大量嵌套链接。我在网上做了一些研究,发现这可能是由于服务器错误(之前完成的分 block 传输编码达到预期大
这个问题似乎以前已经得到解答,但似乎只发生在 Linux 上。 我对文件的唯一导入是 import http.client ,完整错误如下: Error: An error occurred whi
我正在用 python 为 bigcommerce 构建一个应用程序,使用 bigcommerce sdk ( https://github.com/bigcommerce/bigcommerce-a
我已经阅读了许多有关“IncompleteRead”的问题和答案,其中大多数(如果不是全部)最终都会建议卸载并重新安装 pip,或升级 pip,或卸载并重新安装您尝试安装的软件包. 我什至无法升级 p
通过 pip3 安装模块时遇到问题,尝试了 2014 年 12 月投票最高的线程中的几个建议,但仍然得到以下信息: sudo pip3 install send2trash Traceback
我有几个守护进程使用 boto 从 Amazon S3 读取许多文件。每隔几天,我就会遇到一种情况,即 httplib.IncompleteRead 从 boto 的深处被抛出。如果我尝试重试该请求,
当我尝试使用 pip 或 pip3 安装任何东西时,我得到: $ sudo pip3 install python3-tk Traceback (most recent call last): F
我正在尝试使用 beautifulsoup4 和 python3 来抓取 really long web page。由于网站的大小,当我尝试在网站中搜索某些内容时,http.client 会抛出错误:
我试图了解如何处理下面代码中的 http.client.IncompleteRead 错误。我使用 this post 中的想法处理错误.基本上,我认为这可能只是服务器限制了我可以访问数据的次数,但奇
在运行此程序以使用 Python 2.7.8 检索 Twitter 数据时: #imports from tweepy import Stream from tweepy import OAuthHa
使用 Airflow worker 和 webserver/scheduler 作为在 EC2 上的 Kubernetes Engine 上运行的 Docker 镜像 我们有一个包含 Kubernet
我正在使用 Python (2.7.6) 和 Py2Neo (1.6.4) 更新 Neo4j 服务器上的数据。我的加载函数是: from py2neo import neo4j,node, rel,
我正在尝试使用请求模块下载 PDF 文件,代码如下: import requests url = "" r = requests.get(url, stream=True, timeout=(60,
我的 Python 脚本,包含以下行: from requests import post ... while(1): result = readSensors().result payl
使用 tweepy 运行一个 python 脚本,它在英语推文的随机样本中流式传输(使用 twitter 流式 API)一分钟,然后交替搜索(使用 twitter 搜索 API)一分钟,然后返回。我发
我已经在服务器 A 上设置了 neo4j,并且我在服务器 B 上运行了一个应用程序来连接到它。 如果我在服务器 A 上克隆应用程序并运行单元测试,它工作正常。但是在服务器 B 上运行它们,设置运行了
我是一名优秀的程序员,十分优秀!