ActionMailer不在Rails 3.1.1中发送邮件

时间:2011-11-17 14:41:42

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

当我的工作人员尝试发送电子邮件时,我在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

development.rb

  config.action_mailer.delivery_method = :smtp

对可能出错的任何见解?感谢。

3 个答案:

答案 0 :(得分:6)

我遇到了同样的问题,如果从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文件和初始化器之间发生的事情。

答案 1 :(得分: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

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

我要查看你实际连接的位置 - 去smtp代码中添加一些puts语句(在546行或附近):

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

答案 2 :(得分:1)

检查您在:from课程开头定义的ActionMailer密钥