Ruby on Rails правильно настроил http-клиента Фарадея для SSL-соединений - PullRequest
0 голосов
/ 08 января 2019

Я постоянно получаю Failed to open TCP connection to :80 (Cannot assign requested address - connect(2) for nil port 80) (Errno::EADDRNOTAVAIL) при использовании рубинового камня Фарадея. У меня нет большого опыта работы с рубином на рельсах.

У меня есть докер ruby ​​на сервисе рельсов, работающий на эластичном бобовом стебле, который использует puma с ssl. CMD ["bundle", "exec", "puma", "-C", "config/puma.rb"] У меня настроен балансировщик сетевой нагрузки для переадресации 443 -> 8443 (я экспериментировал как с самозаверяющими сертификатами, так и с настоящими групповыми сертификатами).

ssl_bind '0.0.0.0', '8443', {
  key: '/var/app/ssl/something.key',
  cert: '/var/app/ssl/something.crt'
}

Эта конфигурация работает как положено

Puma starting in single mode...
* Version 3.12.0 (ruby 2.5.1-p57), codename: Llamas in Pajamas
* Min threads: 5, max threads: 5
* Environment: staging
* Listening on tcp://0.0.0.0:3000
* Listening on ssl://0.0.0.0:8443?cert=/var/app/ssl/something.crt&key=/var/app/ssl/something.key&verify_mode=none

и я могу получить страницу состояния healthz с обоими типами сертификатов. Использование httpie и --verify=no для собственной подписи.

$ http https://backend.something.com/healthz
HTTP/1.1 200 OK
Cache-Control: max-age=0, private, must-revalidate
Content-Type: application/json; charset=utf-8

{
    "name": "my-backend-service",
    "version": "0.0.1"
}

У меня есть еще один бэкэнд-сервис ruby ​​on rails, который делает api-запросы к этому сервису, используя faraday. Я удалил часть кода request/response из моего фактического.

def connection(baseUrl, options = {})
    conn = Faraday.new(url: baseUrl) do |c|

  # dont really know if this is needed or not
  # http.use_ssl? is always false
  c.adapter :net_http do |http|
      http.verify_mode = OpenSSL::SSL::VERIFY_NONE # if http.use_ssl?
  end
end

Я не знаю, действительно ли это http.verify_mode работает. Я не могу найти этот метод где-нибудь здесь на ruby-doc.org

Если вы попытаетесь сделать запрос, это просто приведет к отказу.

conn = connection(https://backend.something.com)
response = conn.post '/foo', params[:foo].to_json

Журналы показывают от начала до параметров и затем ошибку http.rb:939. Я понимаю, что параметры здесь недействительны, но это не моя проблема.

Started POST "/foo"
Processing by FooController#create as */*
Parameters: {"paramter"=>"something", "paramter"=>"something", "paramter"=>"something"}

ERROR -- : /usr/local/lib/ruby/2.5.0/net/http.rb:939:in `rescue in block in connect': Failed to open TCP connection to :80 (Cannot assign requested address - connect(2) for nil port 80) (Errno::EADDRNOTAVAIL)

Если я сделаю один и тот же запрос от httpie или curl к этому сервису, я получу ожидаемые результаты по обоим http/https.

$ http POST https://backend.something.com parameter="something" parameter="something" parameter="something"
HTTP/1.1 201 Created
Cache-Control: max-age=0, private, must-revalidate
Content-Type: application/json; charset=utf-8

Если вы осмотрите объект conn, он все равно будет выглядеть так, как будто для него установлено значение по умолчанию @url_prefix = http:/. Найдено в документах выше, но я не знаю, правильно ли я смотрю на правильную рубиновую манеру. Я предполагал, что Faraday.new(url: baseUrl) будет анализировать правильную схему, которая является https.

#<Faraday::Connection:0x0000565351701430 @parallel_manager=nil, @headers={"User-Agent"=>"Faraday v0.15.4"}, @params={}, @options=#<Faraday::RequestOptions (empty)>, @ssl=#<Faraday::SSLOptions (empty)>, @default_parallel_manager=nil, @builder=#<Faraday::RackBuilder:0x0000565351700f58 @handlers=[FaradayMiddleware::EncodeJson, FaradayMiddleware::ParseJson, Faraday::Adapter::NetHttp]>, @url_prefix=#<URI::HTTP http:/>, @manual_proxy=false, @proxy=nil, @temp_proxy=nil>

1 Ответ

0 голосов
/ 08 января 2019

Похоже, что адрес, к которому вы пытаетесь подключиться, недействителен. Из того, что я вижу в ошибке:

ERROR -- : /usr/local/lib/ruby/2.5.0/net/http.rb:939:in `rescue in block in connect': Failed to open TCP connection to :80 (Cannot assign requested address - connect(2) for nil port 80) (Errno::EADDRNOTAVAIL)

это ноль. Убедитесь, что хост настроен правильно.

...