gpt4 book ai didi

ruby - ActionMailer 不在 Rails 3.1.1 中发送邮件

转载 作者:数据小太阳 更新时间:2023-10-29 07:45:37 24 4
gpt4 key购买 nike

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

任何关于可能出错的见解?谢谢。

最佳答案

我遇到了同样的问题,如果从 Web 进程或 Rails 控制台中执行,我的 postman 会正确地发送电子邮件,但如果他们排队等待在工作进程中发送,他们会引发 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 文件和初始化程序之间发生了什么。

关于ruby - ActionMailer 不在 Rails 3.1.1 中发送邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8168974/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com