草庐IT

worker-pool

全部标签

ruby-on-rails - Resque Workers 没有在正确的数据库上工作

我将Resque设置为像这样使用数据库6:Resque.redis="localhost:6779:6"然后我开始我的resque如下:$RAILS_ENV=testPIDFILE=./resque.pidQUEUE=*rakeresque:work当我检查worker时,没有:pry(main)>Resque.redis="localhost:6779:6"=>"localhost:6779:6"pry(main)>Resque.workers=>[]但是当我检查数据库0时,我可以看到它在那里:pry(main)>Resque.redis="localhost:6779:0"=>"l

ruby-on-rails - 通过 Heroku 上的 ruby​​ 守护进程 worker 拒绝 Redis 连接

作为“web”Heroku进程运行的Rails3.2.6应用程序正在使用ENV["REDISTOGO_URL"]环境变量连接到Redis:irb(main):002:0>Redis.current=>#-----/initializers/redis.rbifRails.env.development?Redis.current=Redis.newelsifRails.env.test?Redis.current=Redis.newelsifRails.env.production?uri=URI.parse(ENV["REDISTOGO_URL"])Redis.current=Red

ruby-on-rails-3 - sidekiq true god.rb 从不运行我的 worker ,而来自终端的相同命令呢?

运行god.rb来启动和监控Sidekiq这不起作用。在我的sidekiq神配置下。在生产环境中从终端手动运行sidekiq-C/srv/books/current/config/sidekiq.yml确实工作正常,但sidekiqgod.rb配置没有任何想法为什么会发生这种情况?日志中没有太多内容。God.watchdo|w|w.name="sidekiq"w.interval=30.secondsw.start="cd#{ENV['RAILS_ROOT']};sidekiq-C/srv/books/current/config/sidekiq.yml"w.stop="cd#{ENV

ruby-on-rails - Resque 不运行 worker 从队列中选择工作 - Rails

我有一个resque作业要运行。我尝试通过发出命令将我的工作排队到队列中:Resque.enqueue("QUEUE",params)它将作业推送到队列中。我尝试以localhost:3000/resque运行resque接口(interface)。它向我显示待处理的工作。但它也显示没有工作人员在运行。我运行raketask以通过命令启动worker:(QUEUE='*'bundleexecrakeresque:work)。我的redis实例是Resque.redis=#>.当我尝试运行该rake任务时,我也没有收到任何错误。如果您需要更多信息,请告诉我。

java - 使用 Jedis Pool 时管道破裂

我正在使用Jedis在Redis中执行大量插入/读取操作。Redis服务器使用默认配置。当我开始使用几个线程时出现问题,异常是:redis.clients.jedis.exceptions.JedisConnectionException:java.net.SocketException:Pipequebrado(Writefailed)我已经搜索了很多有关此问题的信息,但找不到原因或已解决。我用来执行这些测试的代码如下:publicclassRedisFacade{privatestaticRedisFacadeinstancia=null;//InitializetheConnec

java - 绝地武士 : Could not get a resource from the pool

背景我们的应用程序使用Jedis-2.2.1并连接到Redis-2.6,这是我获取jedis资源的方式:protectedstaticJedisWrappergetRedisUserWrite(StringUDID){if(redisUserWritePools.get(0)==null)init();inthash=hash(UDID);Jedisjedis=redisUserWritePools.get(hash).getResource();jedis.select(dbs.get("redisUserWritePools"+hash));returnnewJedisWrappe

php - Predis 与 laravel 5.5 "No connections available in the pool in Aggregate/RedisCluster.php:337 "

我在AmazonElastiCache上为缓存设置了redis-cluster,使用Laravel5.5和Predis包,我收到以下错误。Predis\ClientException:Noconnectionsavailableinthepoolinvendor/predis/predis/src/Connection/Aggregate/RedisCluster.php:337Trace:Predis\ClientException:Noconnectionsavailableinthepoolinvendor/predis/predis/src/Connection/Aggrega

heroku - 运行 rake 任务以在 Heroku 上启动 Resque worker

所以我在Heroku上设置了Resque和redis,这就是我的resque.rake文件的样子:require'resque/tasks'task"resque:setup"=>:environmentdoENV['QUEUE']='*'enddesc"Aliasforresque:work(TorunworkersonHeroku)"task"jobs:work"=>"resque:work"我运行了herokurakejobs:work并让一名worker运行。这非常有效。我的后台作业正在完成。然后我对我的代码做了一些更改,推送到heroku,仍然看到我有一个worker在运行。

ruby /Resque/Redis : How to set up workers on different machines?

我一直在研究分布式后台作业的resque。通过演示应用程序,我设法让所有东西都在一台机器上运行。但我不知道如何设置一切,以便worker们在不同的机器上运行。我读到worker必须连接到redis服务器。但我仍然不知道从哪里开始。某处有分步说明吗?我没有找到任何关于此的文档。或者谁能给我解释一下?顺便说一句,我不使用Rails,我使用的是Sinatra。谢谢 最佳答案 是的,你是对的,如果你所有的工作人员都可以访问redis,你可以将它们连接起来,将它们分发到不同的机器上为此,您需要将worker连接到redis(我假设所有work

python - 在 Python-RQ 中减少机器上的 worker 数量?

在Python-RQ中减少机器上工作人员数量的好方法是什么?Accordingtothedocumentation,我需要向机器上的工作进程之一发送SIGINT或SIGTERM命令:TakingdownworkersIf,atanytime,theworkerreceivesSIGINT(viaCtrl+C)orSIGTERM(viakill),theworkerwaituntilthecurrentlyrunningtaskisfinished,stoptheworkloopandgracefullyregisteritsowndeath.If,duringthistakedownp