调试 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 用于“工人工作”,例如电子邮件

阻止Sidekiq在测试中打印“(...)INFO:带有redis选项{}的Sidekiq客户端”

Rails,RabbitMQ和Sidekiq架构[关闭]