【问题标题】:ActionMailer not sending mail in Rails 3.1.1ActionMailer 不在 Rails 3.1.1 中发送邮件
【发布时间】:2011-12-31 10:09:35
【问题描述】:

当我的工作人员尝试发送电子邮件时,我在 ActionMailer 中遇到错误

Errno::ECONNREFUSED
    Connection refused - connect(2)

/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:546:in `initialize'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:546:in `open'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:546:in `tcp_socket'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:555:in `block in do_start'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/timeout.rb:58:in `timeout'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/timeout.rb:89:in `timeout'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:555:in `do_start'
/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb:525:in `start'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/mail-2.3.0/lib/mail/network/delivery_methods/smtp.rb:128:in `deliver!'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/mail-2.3.0/lib/mail/message.rb:1989:in `do_delivery'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/mail-2.3.0/lib/mail/message.rb:230:in `block in deliver'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/actionmailer-3.1.1/lib/action_mailer/base.rb:432:in `block in deliver_mail'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/activesupport-3.1.1/lib/active_support/notifications.rb:53:in `block in instrument'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/activesupport-3.1.1/lib/active_support/notifications/instrumenter.rb:21:in `instrument'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/activesupport-3.1.1/lib/active_support/notifications.rb:53:in `instrument'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/actionmailer-3.1.1/lib/action_mailer/base.rb:430:in `deliver_mail'
/Users/bhushan/.rvm/gems/ruby-1.9.2-p290/gems/mail-2.3.0/lib/mail/message.rb:230:in `deliver'
/Users/bhushan/betterlabs_projects/companyplus_beta/cp_frontend/app/workers/set_crawling.rb:29:in `perform'

我在初始化程序中有一个文件 setup_mail.rb,其中包含 smtp 设置

 ActionMailer::Base.smtp_settings = {
 address: "smtp.gmail.com",
 port: 587,
 domain: 'betterlabs.net',  
 user_name: 'policemerepiche@gmail.com',
 password:
 authentication: 'plain',
 enable_starttls_auto: true
 }

还有我的邮件方法

   def send_email(email)
begin
# attachments['result.csv'] = File.read(file)
 mail(to: "bhushanlodha@gmail.com", subject: "hey")
 puts "====Mail Sent===="
 rescue Exception=>e
 puts e.inspect
 end
end

开发.rb

  config.action_mailer.delivery_method = :smtp

对可能出现的问题有任何见解吗?谢谢。

【问题讨论】:

  • 我假设您将ActionMailer::Base.delivery_method 设置为:smtp
  • 我在 development.rb 中有 config.action_mailer.delivery_method = :smtp
  • 你能直接连接到 smtp.gmail.com:587,例如通过远程登录?

标签: ruby ruby-on-rails-3.1 actionmailer


【解决方案1】:

我遇到了同样的问题,如果从 Web 进程或 Rails 控制台执行,我的邮件程序将正确发送电子邮件,但如果他们排队在工作进程中发送,他们会引发 Errno::ECONNREFUSED 异常。

我也使用初始化程序来设置配置。关于它的一切都闻起来好像有 SMTP 设置以某种方式被遗漏了,但只有在由工作进程运行时。

最后我把它添加到了邮件中:

m = mail(to: "herpderp@example.com", subject: "Example")
puts m.to_yaml
return m

这表明邮件实例内部有一个 smtp 设置对象(或从其中引用,并包含在 to_yaml 中),并且该 smtp 设置对象没有我在初始化程序中声明的 smtp 设置。摘录如下:

settings:
  :address: localhost
  :port: 25
  :domain: localhost.localdomain
  :user_name: 
  :password: 
  :authentication: 
  :enable_starttls_auto: true
  :openssl_verify_mode: 
  :ssl: 
  :tls: 

显然这是不正确的。此外,从同一声明打印 Rails.application.config.action_mailer.smtp_settings 正在打印正确的设置

所以为了缩小可能性,我当然将我的设置声明移回 development.rb 并且下次这些设置打印到我的工作人员的标准输出时,它们是正确的,并且电子邮件按预期发送。

所以我不能说我完全了解如何/何时处理初始化程序中设置的配置,因为我对 Rails 核心模块的深度没有太多了解,但我可以说在那里的某个地方,由于邮件实例如何从全局配置中检索 smtp 设置,因此在初始化程序与环境文件中声明它们的方式/时间之间存在差异。

为我吸取的教训。不要使用初始化器类超出标准 Rails 配置标准。将配置移回 development.rb 后,一切都按预期工作。也许其他人可以帮助解释环境 rb 文件和初始化程序之间发生的事情。

【讨论】:

  • 顺便说一句,我使用的 Rails 版本是 3.2.11
  • 很高兴你能分享这个!!我遇到了完全相同的情况并开始流鼻血。在您的帮助下,经过进一步调查,我找到了原因:从 YML 文件加载邮件设置时,键是字符串,而 action_mailer 不喜欢这样。这个实现就像一个魅力(在你的环境文件中):config.action_mailer.smtp_settings = YAML.load_file("#{::Rails.root}/config/mailer.yml")[::Rails.env] 后跟config.action_mailer.smtp_settings.symbolize_keys!
  • 谢谢你!我以为我快疯了。我的初始化程序允许其他的 delivery_method 值和/或散列(例如 sendmail_settings 或 file_settings),所以对于加载的 YML 文件的 each_pair,我改为使用 ActionMailer::Base.send("#{key}=", value.is_a?(Hash) ? value.symbolize_keys! : value )
  • @Benj:谢谢你的评论!! 3 年后,symbolize_keys! 为我节省了数小时的挫败感。
【解决方案2】:

正如上面的 Thilo 所说;显而易见的测试是确定您是否可以连接到 Gmail 的服务器:

$ telnet smtp.gmail.com 587
Trying 74.125.53.108...
Connected to gmail-smtp-msa.l.google.com.
Escape character is '^]'.
220 mx.google.com ESMTP ft1sm69312925igc.3

如果您可以连接,那么您的设置一定不会在引导期间被拾取。

我会检查您实际连接的位置 - 将一些 puts 语句添加到 smtp 代码中(在第 546 行或附近):

/Users/bhushan/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/net/smtp.rb

【讨论】:

    【解决方案3】:

    检查您在ActionMailer 类开头定义的:from

    【讨论】:

    • 我用 :from 方法而不是电子邮件写了名字。这有帮助!
    猜你喜欢
    • 2014-01-13
    • 1970-01-01
    • 2014-12-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-08-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多