我正在尝试向某些用户异步发送电子邮件:
这是昨天完美运行的方法链:
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/