【发布时间】:2013-02-15 11:51:52
【问题描述】:
我正在尝试设置 discourse,这是一个 rails3 webapp,但在使用 gmail smtp 服务器配置 smtp 时遇到了一些问题。
我昨天注册了一个新的gmail账号,可以登录浏览器和邮件客户端软件了。
然后我配置discourse,在文件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 警告:连接被拒绝 - 连接(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:inopen' /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。现在我删除了它,但仍然无法正常工作。
【问题讨论】:
-
尝试添加 :domain => "gmail.com",然后重启你的服务器
标签: ruby-on-rails smtp gmail discourse