Domanda getaddrinfo: nodename né servname fornito o non conosciuto


Ho un'applicazione Ruby on Rails che sto distribuendo su un computer con Mac OS X 10.6. Il codice in cui sorge il problema è gestito da un delayed_job. Il problema si verifica solo quando viene eseguito attraverso delayed_job. Se lo eseguo all'interno di una console (rails console production) o chiama l'API direttamente tramite cURL, funziona senza problemi. Inoltre, l'intero processo funziona senza problemi nel mio ambiente di sviluppo.

Fondamentalmente, il codice funziona in un posto, ma per qualche motivo, fallisce dove deve funzionare. Ho cercato e trovato alcune risorse, ma nessuno dei suggerimenti si applica o fa alcuna differenza. Quando accedo al server ed eseguo i comandi, tutto funziona. Ma per qualche motivo quando vengono eseguiti / avviati da Capistrano, non funziona.

Qualsiasi aiuto è molto apprezzato.

Note importanti:

  • Versione di Ruby: 1.9.2-p0
  • Versione di Rails: 3.0.1
  • versione delayed_job: ultima (da collectiveidea / delayed_job)
  • versione rest-client: 1.6.1

Codice:

class CallApi < Struct.new(:num)
  def perform
    log "Entering perform"
    apinum = num || 5
    log "ApiNum = #{apinum}"
    results = attempt(2,10) do
      ActiveSupport::JSON.decode(RestClient.get(API_URL, {:params => {:apinum => apinum}}))
    end
    log "Results retrieved. (count: #{results.count})"
  end

  def log(message)
    Delayed::Worker.logger.info "[CallApi] #{Time.now} - #{message}"
  end
end

Environment Config (nota: l'url è falso, ma della stessa forma di quello reale):

API_URL = "http://api.example.org/api_endpoint"
# Originally, I had "http://" before the beginning, but found a
# post mentioning that Net::Http.start didn't like that.
# So I tried it both ways.
# The same error occurs regardless of if the "http://" is there.

Chiama dove si verifica l'errore:

RestClient.get(API_URL, {:params => {:apinum => apinum}})

Errore:

getaddrinfo: nodename nor servname provided, or not known
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:644:in `initialize'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:644:in `open'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:644:in `block in connect'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/timeout.rb:44:in `timeout'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/timeout.rb:87:in `timeout'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:644:in `connect'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:637:in `do_start'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/net/http.rb:626:in `start'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/rest-client-1.6.1/lib/restclient/request.rb:166:in `transmit'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/rest-client-1.6.1/lib/restclient/request.rb:60:in `execute'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/rest-client-1.6.1/lib/restclient/request.rb:31:in `execute'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/rest-client-1.6.1/lib/restclient.rb:68:in `get'
/private/var/www/project-gemset/releases/20101109002137/lib/call_api.rb:7:in `block in perform'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/attempt-0.2.0/lib/attempt.rb:70:in `attempt'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/attempt-0.2.0/lib/attempt.rb:114:in `attempt'
/private/var/www/project-gemset/releases/20101109002137/lib/call_api.rb:6:in `perform'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/backend/base.rb:77:in `invoke_job'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:118:in `block (2 levels) in run'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/timeout.rb:57:in `timeout'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:118:in `block in run'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/benchmark.rb:309:in `realtime'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:117:in `run'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:176:in `reserve_and_run_one_job'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:102:in `block in work_off'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:101:in `times'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:101:in `work_off'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:76:in `block (2 levels) in start'
/Users/api/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/benchmark.rb:309:in `realtime'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:75:in `block in start'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:72:in `loop'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/worker.rb:72:in `start'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:100:in `run'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:79:in `block in run_process'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application.rb:250:in `call'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application.rb:250:in `block in start_proc'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/daemonize.rb:199:in `call'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/daemonize.rb:199:in `call_as_daemon'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application.rb:254:in `start_proc'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application.rb:294:in `start'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application_group.rb:159:in `block (2 levels) in start_all'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application_group.rb:158:in `fork'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application_group.rb:158:in `block in start_all'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application_group.rb:157:in `each'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/application_group.rb:157:in `start_all'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/controller.rb:80:in `run'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons.rb:193:in `block in run_proc'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/cmdline.rb:112:in `call'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons/cmdline.rb:112:in `catch_exceptions'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/gems/daemons-1.1.0/lib/daemons.rb:192:in `run_proc'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:78:in `run_process'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:72:in `block in daemonize'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:70:in `times'
/Users/api/.rvm/gems/ruby-1.9.2-p0@project-gemset/bundler/gems/delayed_job-aba9905764c2/lib/delayed/command.rb:70:in `daemonize'
script/delayed_job:5:in `'

58
2017-11-09 10:14


origine


risposte:


L'errore si verifica quando la risoluzione DNS non riesce. Controlla se puoi wget (o arricciare) l'api url dalla riga di comando. Cambiare il server DNS e testarlo potrebbe aiutare.


47
2017-11-09 11:43



resto-client di RestClient ha bisogno del http: schema durante la risoluzione dell'URL. Chiama Net::HTTP per te, che non vuole il http: parte, ma il resto-cliente si prende cura di questo.

L'URL è l'attuale che stai tentando di raggiungere? example.org è un dominio valido utilizzato per test e documentazione ed è raggiungibile; Mi aspetterei che le parti "api" e "api_endpoint" falliscano e lo vedremo quando cercherò di raggiungerle.

require 'socket'

IPSocket.getaddress('example.org') # => "2620:0:2d0:200::10"
IPSocket.getaddress('api.example.org') # => 
# ~> -:7:in `getaddress': getaddrinfo: nodename nor servname provided, or not known (SocketError)
# ~>    from -:7:in `<main>'

Ecco cosa ottengo usando Curl:

greg-mbp-wireless:~ greg$ curl api.example.org/api_endpoint
curl: (6) Couldn't resolve host 'api.example.org'
greg-mbp-wireless:~ greg$ curl example.org/api_endpoint
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</head><body>
<h1>Not Found</h1>
<p>The requested URL /api_endpoint was not found on this server.</p>
<hr>
<address>Apache Server at example.org Port 80</address>
</body></html>
greg-mbp-wireless:~ greg$ curl example.org
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<HTML>
<HEAD>
  <META http-equiv="Content-Type" content="text/html; charset=utf-8">
  <TITLE>Example Web Page</TITLE>
</HEAD> 
<body>  
<p>You have reached this web page by typing &quot;example.com&quot;,
&quot;example.net&quot;,&quot;example.org&quot
  or &quot;example.edu&quot; into your web browser.</p>
<p>These domain names are reserved for use in documentation and are not available 
  for registration. See <a href="http://www.rfc-editor.org/rfc/rfc2606.txt">RFC 
  2606</a>, Section 3.</p>
</BODY>
</HTML>

9
2017-11-10 05:39



Oggi mi sono imbattuto in una situazione simile: distribuire un'applicazione a un server Mac OS X e ricevere il messaggio "getaddrinfo" quando ho provato ad accedere a una API esterna. Si scopre che l'errore si verifica quando la sessione ssh che ha lanciato l'app in origine non è più attiva. Ecco perché tutto funziona perfettamente se si esegue l'ssh sul server e si eseguono i comandi manualmente (o si avvia il server manualmente), a patto che si mantenga attiva la sessione ssh, questo errore non si verificherà.

Non sono sicuro se si tratti di un bug o di una stranezza in OS X. Ecco la pagina che mi ha portato alla soluzione - http://lists.apple.com/archives/unix-porting/2010/Jul/msg00001.html

Tutto quello che dovevo fare era aggiornare la mia attività capistrano per avviare l'app usando 'nohup'. Quindi cambiando

run "cd #{current_path} && RAILS_ENV=production unicorn_rails -c config/unicorn.rb -D"

a

run "cd #{current_path} && RAILS_ENV=production nohup unicorn_rails -c config/unicorn.rb -D"

ha fatto il trucco per me.

Spero che questo aiuti qualcuno - è stato abbastanza doloroso capire!


8
2018-02-13 22:15



Ho riavviato il mio computer (Mac Mountain Lion) e il problema si è risolto. Qualcosa che ha a che fare con la shell pensando che sia stato disconnesso da internet, credo.

Riavviare la shell in un modo definito può risolvere anche questo problema. Semplicemente aprendo una nuova sessione / finestra, tuttavia, non ha funzionato.


4
2018-06-02 22:45



Ho risolto questo problema semplicemente chiudendo e riaprendo il terminale.


4
2017-11-26 13:56



Ho ottenuto lo stesso errore quando controllo che localhost sia impostato nel file hosts in qualche modo non impostato. Impostando localhost su 127.0.0.1 risolto.

sudo vi /etc/hosts
>>

127.0.0.1       localhost

3
2017-07-06 07:37



Stavo vedendo questo errore estraneo ai binari. Si è scoperto che il mio test stava tentando di utilizzare una porta troppo alta (maggiore di 65535).

Questo codice produrrà l'errore in questione

require 'socket'
Socket.getaddrinfo("127.0.0.1", "65536")

2
2018-05-06 17:20



Per evitare questo problema, possiamo legare a 127.0.0.1 invece di localhost:

bin/rails server -b 127.0.0.1


1
2018-03-18 05:00



Ho avuto l'errore mentre cercavo di svilupparmi mentre ero disconnesso da Internet. Tuttavia, il sito web su cui stavo lavorando deve essere in grado di parlare con altri siti Web, quindi si è bloccato quando non è stato possibile farlo. La connessione a Internet ha corretto l'errore.


0
2017-12-20 16:57



Se tutto quanto sopra non riesce, prova a convertire in UNIX Line Endings, oppure:

brew install dos2unix
sudo dos2unix -c mac /private/etc/hosts

Forse la codifica degli host è sbagliata.

spero che questo ti aiuti


0
2018-02-06 03:09