2016-03-22 32 views
1

Ich benutze wercker zum Ausführen von Spezifikationen meiner Schienen App. Ich habe Probleme mit der Einrichtung von redis auf wercker. In meiner Schienen-app habe ich redis.rb, die wie folgt aussieht:Fehler beim Verbinden mit Redis auf 127.0.0.1:6379 (Errno :: ECONNREFUSED) - Wercker

if Figaro.env.rediscloud_url 
    uri = URI.parse(Figaro.env.rediscloud_url) 
    REDIS = Redis.new(host: uri.host, port: uri.port, password: uri.password) 
elsif ENV['WERCKER_REDIS_HOST'] && ENV['WERCKER_REDIS_PORT'] 
    REDIS = Redis.new(host: ENV['WERCKER_REDIS_HOST'], port: ENV['WERCKER_REDIS_PORT']) 
else 
    REDIS = Redis.new 
end 

In wercker stelle ich WERCKER_REDIS_HOST enviromental Variable: 127.0.0.1 und WERCKER_REDIS_PORT zu 6379

Wenn ich meine Brille starten Sie es zurück:

Redis::CannotConnectError: 
Error connecting to Redis on 127.0.0.1:6379 (Errno::ECONNREFUSED) 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:332:in `rescue in establish_connection' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:318:in `establish_connection' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:94:in `block in connect' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:280:in `with_reconnect' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:93:in `connect' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:351:in `ensure_connected' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:208:in `block in process' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:293:in `logging' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:207:in `process' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:178:in `call_pipelined' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:150:in `block in call_pipeline' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:280:in `with_reconnect' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/client.rb:148:in `call_pipeline' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis.rb:2245:in `block in multi' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis.rb:57:in `block in synchronize' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis.rb:57:in `synchronize' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis.rb:2237:in `multi' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/sidekiq-4.1.0/lib/sidekiq/client.rb:171:in `block in raw_push' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/connection_pool-2.2.0/lib/connection_pool.rb:64:in `block (2 levels) in with' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/connection_pool-2.2.0/lib/connection_pool.rb:63:in `handle_interrupt' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/connection_pool-2.2.0/lib/connection_pool.rb:63:in `block in with' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/connection_pool-2.2.0/lib/connection_pool.rb:60:in `handle_interrupt' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/connection_pool-2.2.0/lib/connection_pool.rb:60:in `with' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/sidekiq-4.1.0/lib/sidekiq/client.rb:170:in `raw_push' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/sidekiq-4.1.0/lib/sidekiq/client.rb:67:in `push' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/sidekiq-4.1.0/lib/sidekiq/worker.rb:115:in `client_push' 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/sidekiq-4.1.0/lib/sidekiq/extensions/generic_proxy.rb:19:in `method_missing' 
# ./app/models/user.rb:26:in `send_reset_password_instructions' 
# ./spec/models/user_spec.rb:43:in `block (3 levels) in <top (required)>' 
# ------------------ 
# --- Caused by: --- 
# IO::EINPROGRESSWaitWritable: 
# Operation now in progress - connect(2) would block 
# /pipeline/cache/bundle-install/ruby/2.3.0/gems/redis-3.2.2/lib/redis/connection/ruby.rb:122:in `connect_addrinfo' 

Wie kann ich das beheben?

+0

Funktioniert es, wenn Sie vor dem Anschließen eines Schlaf hinzufügen? Ich habe Fälle gesehen, in denen der Start von redis oder mysql etwas länger dauert und die Build-Schritte versuchen, zu schnell darauf zuzugreifen. Es gibt einen "service-ready" -Schritt oder etwas Ähnliches, benutze das. – ZeissS

+0

doppelt überprüft - der Schritt heißt "Service-Check": https://app.wercker.com/#applications/565702a38faa27fb0d1db58a/tab/details/ – ZeissS

Antwort

1

hatte ich das gleiche Problem, aber ich fand einen Fix:

starten Redis manuell im Terminal mit redis-server