通过SSL发布UTF-8时,HEROKU上的"EOFError:文件结束"

Dmi*_*nik 8 ruby https ruby-on-rails heroku ruby-on-rails-3

我在heroku上有一个奇怪的错误.为了重现它,我必须在请求体中使用任何UTF-8字符进行大的(超过几KB)HTTPS POST.这是一个例子:

require "net/https"
require "uri"

#Accutally I've ecountered this bug while posting to another server
url = URI.parse("https://api.heroku.com/myapps")

#It's Ukrainian 'oiced velar plosive G' letter
payload = "?"*10000
request = Net::HTTP::Post.new(url.path)
request.body = payload
http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true
http.read_timeout = 500
http.start {|http| http.request request }
Run Code Online (Sandbox Code Playgroud)

在本地机器的irb上运行这样的脚本给了我:

#<Net::HTTPUnauthorized 401 Unauthorized readbody=true> 
Run Code Online (Sandbox Code Playgroud)

......这是预期的,但是在heroku雪松上,在"heroku控制台"上运行...在大约60秒内,我得到:

EOFError: end of file reached
    from /usr/local/lib/ruby/1.9.1/openssl/buffering.rb:145:in `sysread_nonblock'
    from /usr/local/lib/ruby/1.9.1/openssl/buffering.rb:145:in `read_nonblock'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:135:in `rbuf_fill'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:116:in `readuntil'
    from /usr/local/lib/ruby/1.9.1/net/protocol.rb:126:in `readline'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:2219:in `read_status_line'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:2208:in `read_new'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:1191:in `transport_request'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:1177:in `request'
    from (irb):32:in `block in irb_binding'
    from /usr/local/lib/ruby/1.9.1/net/http.rb:627:in `start'
    from (irb):32
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands/console.rb:47:in `start'
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands/console.rb:8:in `start'
    from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.7/lib/rails/commands.rb:41:in `<top (required)>'
Run Code Online (Sandbox Code Playgroud)

我该怎么办?

Dmi*_*nik 3

我必须将 ruby​​ 版本添加到Gemfile中,因为默认 Cedar 的 ruby​​ 是 1.9.2(在通过 SSL 传递 UTF-8 字符串时存在错误)

source 'https://rubygems.org'
ruby "1.9.3"

gem 'rails', '3.2.7'
gem 'pg'
...
Run Code Online (Sandbox Code Playgroud)