我们有一个 Ruby on Rails 应用程序,它具有“搜索”功能(搜索某些公司)。从浏览器用户键入一些名称并点击搜索,此搜索对外部系统进行休息 api 调用并为我们提供一些搜索结果。
我们正在使用“ rest-client ”(用于 Ruby on Rails)。
我注意到这似乎工作了几个小时,突然我的搜索似乎突然中断了,我可以在我的日志中看到我得到:
Errno::ECONNRESET:对等方重置连接
我们试图通过查看日志来调查此问题,但我们没有看到任何日志。
如果我们需要让这个搜索再次工作,我们需要重新启动乘客,然后它会立即工作。这仅在生产环境中发生。我在分期中进行了测试,它似乎运行良好。
问题:
- 什么可能导致这个“重置问题”
- 为什么在我的 prod 乘客重置时它又开始工作了。
- 我们使用reset-client 应该写一个代码来在这个异常发生时手动关闭连接。
- 防火墙中的任何问题都可能导致这种情况?
- 是否可以在异常中放置任何代码来重新启动此连接,以便下一次调用成功。
代码:
def call
resp_data = RestClient.get(@request_url, @header)
rescue => error
puts 'Exception: ' error.message
end