Rails POST:heroku上的“SocketError:getaddrinfo:名称解析暂时失败”,但不是本地的

时间:2012-09-10 20:06:12

标签: ruby-on-rails heroku http-post

我正在尝试对外观服务执行Rails POST请求,其外观大致如下:

def self.send_post_request(domain, data)
 uri = URI.parse(domain)
 http = Net::HTTP.new(uri.host, uri.port)
 request = Net::HTTP::Post.new(uri.request_uri)
 request.set_form_data(data)
 http.use_ssl = true if domain =~ /^https/
 response = http.request(request)
end

它在本地工作正常但是一旦我部署到heroku,我就会收到此错误:

SocketError: getaddrinfo: Temporary failure in name resolution

有关如何解决这个问题的想法吗?

非常感谢您的帮助!!

编辑:这些是我在相应模型中包含的库:

require "net/http"
require "net/https"
require "uri"

这是实际错误后控制台抛出的内容:

from /usr/local/lib/ruby/1.9.1/net/http.rb:644:in `initialize'
from /usr/local/lib/ruby/1.9.1/net/http.rb:644:in `open'
from /usr/local/lib/ruby/1.9.1/net/http.rb:644:in `block in connect'
from /usr/local/lib/ruby/1.9.1/timeout.rb:44:in `timeout'
from /usr/local/lib/ruby/1.9.1/timeout.rb:89:in `timeout'
from /usr/local/lib/ruby/1.9.1/net/http.rb:644:in `connect'
from /usr/local/lib/ruby/1.9.1/net/http.rb:637:in `do_start'
from /usr/local/lib/ruby/1.9.1/net/http.rb:626:in `start'
from /usr/local/lib/ruby/1.9.1/net/http.rb:1168:in `request'
from /app/app/models/message.rb:224:in `send_post_request'
from /app/app/models/message.rb:46:in `opt_in_text'
from (irb):2
from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.6/lib/rails/commands/console.rb:47:in `start'
from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.6/lib/rails/commands/console.rb:8:in `start'
from /app/vendor/bundle/ruby/1.9.1/gems/railties-3.2.6/lib/rails/commands.rb:41:in `<top (required)>'

1 个答案:

答案 0 :(得分:5)

它看起来像连接暂时失败,可能在你的函数中重试?

def self.send_post_request(domain, data, retry_attempts=0)
  uri = URI.parse(domain)
  http = Net::HTTP.new(uri.host, uri.port)
  request = Net::HTTP::Post.new(uri.request_uri)
  request.set_form_data(data)
  http.use_ssl = true if domain =~ /^https/
  response = http.request(request)
rescue SocketError => error
  if retry_attempts > 0
    retry_attempts -= 1
    sleep 5 
    retry
  end
  raise
end