我正在尝试设置discourse,这是一个 rails3 webapp,但是在使用 gmail smtp 服务器配置 smtp 时遇到了一些问题。
我昨天注册了一个新的gmail帐户,我可以登录浏览器和电子邮件客户端软件。
然后我在文件中配置话语config/environments/production.rb
:
config.action_mailer.delivery_method = :smtp
config.action_mailer.smtp_settings = {
:address => "smtp.gmail.com",
:port => "587",
:user_name => "smtp4shuzu@gmail.com",
:password => "12345678",
:authentication => :plain,
:domain => "shuzhu.org",
:enable_starttls_auto => true
}
启动sidekiq
用于在后台发送邮件:
nohup bundle exec sidekiq > log/sidekiq.log 2>&1 &
然后在生产模式下开始话语:
rails server -e production -d
但它不起作用。我可以看到一些错误sidekiq.log
:
2013-03-01T03:06:02Z 30687 TID-qib28 WARN: {"retry"=>true, "queue"=>"default", "class"=>"Jobs::UserEmail", "args"=>[ {"type"=>"signup", "user_id"=>42, "email_token"=>"b40a21ece2b14586e346abfd96685975", "current_site_id"=>"default"}], "jid"=>"558bb6bd5aa36cfc8d3d1e91", "error_message"= >“连接被拒绝 - connect(2)”、“error_class”=>“Errno::ECONNREFUSED”、“failed_at”=>2013-03-01 03:06:02 UTC、“retry_count”=>0} 2013-03 -01T03:06:02Z 30687 TID-qib28 警告:连接被拒绝 - connect(2) 2013-03-01T03:06:02Z 30687 TID-qib28 警告:/home/discourse/.rvm/rubies/ruby-1.9.3- p385/lib/ruby/1.9.1/net/smtp。rb:540:in
initialize' /home/discourse/.rvm/rubies/ruby-1.9.3-p385/lib/ruby/1.9.1/net/smtp.rb:540:in
open' /home/discourse/.rvm/rubies/ruby-1.9.3-p385/lib/ruby/1.9.1/net/smtp.rb:540:in `tcp_socket'
我已经尝试了各种 smtp 设置,但都不起作用。
更新:
根据@Basil的回答,我刚试过:
config.action_mailer.delivery_method = :smtp
config.action_mailer.smtp_settings = {
:address => "smtp.gmail.com",
:port => 587,
:user_name => "smtp4shuzu",
:password => "12345678",
:authentication => "plain",
:enable_starttls_auto => true
}
但它有同样的错误。域shuzu.org
是我网站的域,我想我应该将它传递给 smtp。现在我删除了它,但仍然无法正常工作。