我有几个用R编写的程序,它们使用bigrquery来运行查询,表删除和上传数据。这些都是在R studio中使用R版本3.3.1在Windows 7机器上编写的。没有问题一遍又一遍地运行它们。
一名新员工试图在Windows 10上运行相同的程序。相同版本的基础R和R工作室。包都安装正常,没有任何错误。但是通过代码发送到bigquery的命令(即query_exec,insert_upload_job)将提交,但它们会挂起几分钟,然后返回以下错误:
curl :: curl_fetch_memory(url,handle = handle)出错: HTTP / 2成帧层中的流错误
这些查询通常在2秒内运行。这些命令在基本R中在同一台机器上快速运行,没有错误。
我家里有一台Windows 10笔记本电脑,所以我以相同的方式安装了一切,它显示的是同样的行为。在返回上面的错误之前,命令在基本R中运行良好,但在R studio中“挂起”几分钟。
奇怪的是,周期性相同的命令在R studio中运行良好,但大多数时候我们都会收到错误。
我找了这个问题,发现: RHUB / RHUB#32
但我无法弄清楚如何在客户端关闭http2以查看是否有帮助。
我注意到的一件事是当我检查卷曲版本时: 卷曲:: curl_version() 它在我的Windows 7机器上显示版本7.47.1(有效的版本)并且它没有显示http2值。
在Windows 10计算机上,它显示curl版本7.53.1,并显示http2 = TRUE参数。
我无法弄清楚如何弃用Win10机器上的curl版本,看看是否能解决问题。
无论如何,我认为如果最新版本的问题是其他人会遇到同样的问题。
我也将此发布到bigrquery github问题页面,但到目前为止还没有人回复。
感谢任何帮助!
答案 0 :(得分:2)
我通过执行以下步骤创建了一种解决方法:
删除了我的基础R win-library子文件夹中的curl文件夹(当我尝试安装旧版本的curl时,它无法自动删除当前版本)
安装curl版本0.9.7(此版本不使用http2)
install.packages("https://cloud.r-project.org/bin/windows/contrib/3.1/curl_0.9.7.zip", repos=NULL,type="source")
运行curl::curl_version()
确认没有http2参数。
从长远来看,仍有人需要解决问题。我已经将它发布在github存储库上用于bigrquery,但是我不确定他们是否需要修复它或者是否需要在curl()函数中进行修复。
答案 1 :(得分:0)
无需降级curl
来解决error in the HTTP2 framing layer。相反,您可以使用以下方法之一来设置特定的http_version
。
对于使用httr
软件包的用户,您可以像这样直接指定首选的HTTP版本:
# 0 stands for CURL_HTTP_VERSION_NONE (see http_version values below)
httr::set_config(httr::config(http_version = 0))
建议使用此解决方法here。
软件包小插图curl
中提供了另一个如何使用here直接设置选项的(较低级别)示例。摘录:
h <- curl::new_handle()
curl::handle_setopt(h, http_version = 0)
# then use the handle to make a request
# see curl vignettes for an example
有关RCurl
的示例,请参见TLS v1.1 / TLS v1.2 support in RCurl。
curl HTTP版本号在C enum中定义的curl header file on GitHub中可用(链接指向较早的提交):
enum {
CURL_HTTP_VERSION_NONE, /* 0, setting this means we don't care, and that we'd
like the library to choose the best possible
for us! */
CURL_HTTP_VERSION_1_0, /* 1, please use HTTP 1.0 in the request */
CURL_HTTP_VERSION_1_1, /* 2, please use HTTP 1.1 in the request */
CURL_HTTP_VERSION_2_0, /* 3, please use HTTP 2 in the request */
CURL_HTTP_VERSION_2TLS, /* 4, use version 2 for HTTPS, version 1.1 for HTTP */
CURL_HTTP_VERSION_2_PRIOR_KNOWLEDGE, /* 5, please use HTTP 2 without HTTP/1.1
Upgrade */
CURL_HTTP_VERSION_LAST /* 6, *ILLEGAL* http version */
};