【发布时间】: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,这也无济于事?
【问题讨论】:
标签: ruby-on-rails redis sidekiq