ruby-on-rails - 调试 redis、rails 和 sidekiq

标签 ruby-on-rails redis sidekiq

我正在尝试向某些用户异步发送电子邮件:

这是昨天完美运行的方法链:

DiscussionMailer.delay.new_reply_notification()

在控制台中运行它似乎完美无缺,因为它会返回工作人员 ID。我可能错了,这就是那个键实际上是什么,但正如您所看到的,从事情的 rails 方面来看,一切正常。

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" 

然而,事实并非如此。从经验和 rails 炮日志来看,电子邮件无法接近 rails 炮。这似乎是因为 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 没有帮助吗?

最佳答案

错误信息:

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

关于ruby-on-rails - 调试 redis、rails 和 sidekiq,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23451492/

相关文章:

php - 将一个非常大的 php 代码库迁移到 Rails 的理想方式是什么?

ruby - 使用 RSpec 3 测试 sidekiq perform_in

ruby-on-rails - 同一个应用程序中的 Heroku Delayed Job 和 Sidekiq

Heroku 上的 Python Redis 达到最大客户端

ruby-on-rails - sidekiq 进程中的 Rails.cache.read

mysql远程ssl

ruby-on-rails - Rails 3.0.0.beta 和 Facebooker : anyone else seeing the following?

ruby-on-rails - 如何在裸域中配置 Google Domains + Heroku

redis - redis 中的键空间是什么?

redis - 故障后如何重启redis集群节点