调试 redis、rails 和 sidekiq
Posted
技术标签:
【中文标题】调试 redis、rails 和 sidekiq【英文标题】:Debug redis, rails and sidekiq 【发布时间】:2014-05-04 01:06:12 【问题描述】:我正在尝试向某些用户异步发送电子邮件:
这是昨天完美运行的方法链:
DiscussionMailer.delay.new_reply_notification()
在控制台中运行它似乎可以完美运行,因为它返回了工作人员 ID。我可能错了,这就是那个键实际上是什么,但正如你所见,从事情的轨道方面来看,一切都在工作。
2.0.0p247 :004 > DiscussionMailer.delay.new_reply_notification(User.last, Reply.last, Discussion.last, Forum.last )
User Load (0.6ms) SELECT "users".* FROM "users" ORDER BY "users"."id" DESC LIMIT 1
Reply Load (0.2ms) SELECT "replies".* FROM "replies" ORDER BY "replies"."id" DESC LIMIT 1
Discussion Load (0.2ms) SELECT "discussions".* FROM "discussions" ORDER BY "discussions"."id" DESC LIMIT 1
Forum Load (0.2ms) SELECT "forums".* FROM "forums" ORDER BY "forums"."id" DESC LIMIT 1
2014-05-04T00:54:45Z 48591 TID-5s8e0 INFO: Sidekiq client with redis options
=> "3c35e763a23304e3f7e39e1e"
然而,事实并非如此。从经验和轨道炮日志来看,电子邮件在轨道炮附近没有任何进展。这似乎是因为 redis 没有做任何事情:
_._
_.-``__ ''-._
_.-`` `. `_. ''-._ Redis 2.6.13 (00000000/0) 64 bit
.-`` .-```. ```\/ _.,_ ''-._
( ' , .-` | `, ) Running in stand alone mode
|`-._`-...-` __...-.``-._|'` _.-'| Port: 6379
| `-._ `._ / _.-' | PID: 48750
`-._ `-._ `-./ _.-' _.-'
|`-._`-._ `-.__.-' _.-'_.-'|
| `-._`-._ _.-'_.-' | http://redis.io
`-._ `-._`-.__.-'_.-' _.-'
|`-._`-._ `-.__.-' _.-'_.-'|
| `-._`-._ _.-'_.-' |
`-._ `-._`-.__.-'_.-' _.-'
`-._ `-.__.-' _.-'
`-._ _.-'
`-.__.-'
[48750] 04 May 02:02:48.687 # Server started, Redis version 2.6.13
[48750] 04 May 02:02:48.687 * DB loaded from disk: 0.001 seconds
[48750] 04 May 02:02:48.687 * The server is now ready to accept connections on port 6379
我应该得到一些反馈,对吧?
我关闭了 redis 服务器并尝试了同样的事情,我得到了:
Redis::CannotConnectError: Error connecting to Redis on 127.0.0.1:6379 (ECONNREFUSED)
这很好,因为它表明redis和sidekiq可以通信,但不好,因为上帝的名字是怎么回事?我应该如何调试这个问题? railgun 日志和 rails 日志都是无用的。 我在哪里可以找到 redis 日志? 或者因为工人(或者不管他们是什么,几个小时前才了解 redis)甚至没有“接触”redis,这也无济于事?
【问题讨论】:
【参考方案1】:错误信息:
Redis::CannotConnectError: Error connecting to Redis on 127.0.0.1:6379 (ECONNREFUSED)
不是 Redis 和 Sidekiq 通信,看起来您的应用程序的 redis gem 无法与应用程序本地主机的端口 6379 上的 Redis 服务器通信。
您需要启动您的 Redis 服务器,然后启动并运行您的 Sidekiq 服务器。启动每个程序的过程取决于您对每个程序的配置。
至于您的日志,当您启动每个服务器时,您会希望将它们的输出导出到一个日志文件中。所以你应该在你的机器上的某个地方创建一个空的日志文件,然后当你去启动服务器时你修改你的命令:
redis-server > /path/to/your/redis.log 2>&1
【讨论】:
【参考方案2】:看起来您还没有启动/重新启动 sidekiq。去做吧,它会起作用的。
【讨论】:
以上是关于调试 redis、rails 和 sidekiq的主要内容,如果未能解决你的问题,请参考以下文章
在多线程 Rails 环境中使用 Redis 的最佳方式是啥? (彪马/Sidekiq)
Docker-compose 与 redis、sidekiq、rails SocketError
在 AWS Elastic Beanstalk 上配置 Rails、Sidekiq、Redis 的可持续解决方案
Rails 6 应用程序如何将 Sidekiq+Redis 用于 Hotwire/Stimulus,而将 DelayedJob 用于“工人工作”,例如电子邮件