HTTP / 2成帧层中的流错误:R Studio中的bigrquery命令错误,但在基础R

时间:2017-06-18 01:04:19

标签: r curl google-bigquery rstudio

我有几个用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问题页面,但到目前为止还没有人回复。

感谢任何帮助!

2 个答案:

答案 0 :(得分:2)

我通过执行以下步骤创建了一种解决方法:

  1. 删除了我的基础R win-library子文件夹中的curl文件夹(当我尝试安装旧版本的curl时,它无法自动删除当前版本)

  2. 安装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")
    
  3. 运行curl::curl_version()确认没有http2参数。

    从长远来看,仍有人需要解决问题。我已经将它发布在github存储库上用于bigrquery,但是我不确定他们是否需要修复它或者是否需要在curl()函数中进行修复。

答案 1 :(得分:0)

无需降级curl来解决error in the HTTP2 framing layer。相反,您可以使用以下方法之一来设置特定的http_version

方法1-httr

对于使用httr软件包的用户,您可以像这样直接指定首选的HTTP版本:

# 0 stands for CURL_HTTP_VERSION_NONE (see http_version values below)
httr::set_config(httr::config(http_version = 0))

建议使用此解决方法here

方法2-curl或RCurl

软件包小插图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

http_version值

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 */
};