開発環境では問題無かったのですが、デプロイ後に動作確認したところ「500 Internal Server Error」が出てしまいます。logを確認しましたが、ハッキリした原因がわかりません。
production.log I, [2019-05-20T01:17:54.710837 #28258] INFO -- : Started PATCH "/admin/registers/2" for 1XX.21XX。XX. at 2019-05-20 01:17:54 +0900 I, [2019-05-20T01:17:54.720274 #28258] INFO -- : Processing by Admin::RegistersController#update as HTML I, [2019-05-20T01:17:54.720767 #28258] INFO -- : Parameters: {"utf8"=>"✓", "authenticity_token"=>"UGfhhs4keV7w・・・・・==", "form"=>{"register"=>{"rg_1"=>"退会", "rg_2"=>"退会", "rg_3"=>"退会", "rg_4"=>"在籍", "rg_5"=>"在籍", "rg_6"=>"在籍", "rg_7"=>"退会", "rg_8"=>"退会", "rg_9"=>"退会", "rg_10"=>"退会", "rg_11"=>"退会", "rg_12"=>"退会"}}, "commit"=>"更新", "host"=>"wonder-gate.com", "id"=>"2"} I, [2019-05-20T01:17:54.766076 #28258] INFO -- : Rendering register_mailer/next_payment.html.erb within layouts/mailer I, [2019-05-20T01:17:54.769285 #28258] INFO -- : Rendered register_mailer/next_payment.html.erb within layouts/mailer (2.7ms) I, [2019-05-20T01:17:54.769971 #28258] INFO -- : Rendering register_mailer/next_payment.text.erb within layouts/mailer I, [2019-05-20T01:17:54.771125 #28258] INFO -- : Rendered register_mailer/next_payment.text.erb within layouts/mailer (0.9ms) I, [2019-05-20T01:17:56.286496 #28258] INFO -- : Sent mail to XXXXX@gmail.com (1510.8ms) I, [2019-05-20T01:17:56.288662 #28258] INFO -- : Rendering errors/internal_server_error.html.erb within layouts/admin I, [2019-05-20T01:17:56.288966 #28258] INFO -- : Rendered errors/internal_server_error.html.erb within layouts/admin (0.1ms) I, [2019-05-20T01:17:56.292547 #28258] INFO -- : Rendered admin/shared/_header.html.erb (0.9ms) I, [2019-05-20T01:17:56.292958 #28258] INFO -- : Rendered shared/_footer.html.erb (0.1ms) I, [2019-05-20T01:17:56.293465 #28258] INFO -- : Completed 500 Internal Server Error in 1572ms (Views: 5.7ms | ActiveRecord: 6.7ms)
ためしにコンソールで送信出来るか確認してみました。
> user = Customer.find(2) emailカラムには送信先のメールアドレスが記載されています。 今回は、自分のアドレスで試しています。 > RegisterMailer.next_payment(user).deliver_now Net::SMTPFatalError: 555 5.5.2 Syntax error. u38sm41434419pgn.73 - gsmtp
Net::SMTPFatalError: 555 5.5.2 Syntax error. u38sm41434419pgn.73 - gsmtpが発生しました。調べてみるとアドレス関係のエラーっぽいようです。
開発中にはメール送信ができていましたがなぜか、デプロイ後はメールの送信が出来なくなっています。メールの設定は以下のようにしています。
config/environments/production.rb config.action_mailer.delivery_method = :smtp config.action_mailer.raise_delivery_errors = true config.action_mailer.smtp_settings = { address: 'smtp.gmail.com', port: 587, user_name: ENV["GMAIL_USERNAME"], #送信元メールアドレス password: ENV["GMAIL_PASSWORD"], domain: 'smtp.gmail.com', authentication: 'plain', enable_starttls_auto: true }
registers_controller.rb def update @time = Time.zone.now @month = @time.month if @month == 1 @last_month = 12 @next_month = 2 elsif @month == 12 @last_month = 11 @next_month = 1 else @last_month = @time.month - 1 @next_month = @time.month + 1 end @register_form = Admin::RegisterForm.new(Register.find_by(customer_id: params[:id])) @register_form.assign_attributes(params[:form]) if @register_form.save flash.notice = '更新しました。' reg = Register.find_by(customer_id: params[:id]) if reg["rg_#{@last_month}"] == "退会" if reg["rg_#{@month}"] == "在籍" if reg["rg_#{@next_month}"] == "在籍" user = Customer.find_by(id: params[:id]) RegisterMailer.new_payment(user).deliver_now end end else if reg["rg_#{@last_month}"] == "在籍" if reg["rg_#{@month}"] == "在籍" if reg["rg_#{@next_month}"] == "在籍" user = Customer.find_by(id: params[:id]) RegisterMailer.next_payment(user).deliver_now #ここでエラー発生 elsif reg["rg_#{@month}"] == "在籍" user = Customer.find_by(id: params[:id]) RegisterMailer.payment(user).deliver_now end end end end redirect_to :admin_customers else flash.now.alert = '入力に誤りがあります。' render action: 'edit' end end end
app/mailers/register_mailer.rb def next_payment(user) @time = Time.zone.now @month = @time.month if @month == 1 @last_month = 12 @next_month = 2 elsif @month == 12 @last_month = 11 @next_month = 1 else @last_mont = @time.month - 1 @next_month = @time.month + 1 end @user = user mail to: user.email, subject: "ありがとうございます。" end
app/mailers/apprication_mailer.rb class ApplicationMailer < ActionMailer::Base default from: '運営局' layout 'mailer' end
syntax errorなのでどこかが間違っているのだと思います。development.rbとproduction.rbのSMTP設定部分は全て同じにしています。しかし、開発時には送信ができて、VPSでは送信が出来ないということはどこかの設定を変更しないといけないのでしょうがどこを変更すればいいのかわかりません。
どなたか教えていただけないでしょうか?宜しくお願いします。
追記
VPS側のFirewallの設定がおかしいのでしょうか?
firewall-cmd --list-all public (active) target: default icmp-block-inversion: no interfaces: eth0 sources: services: dhcpv6-client ssh http https smtp ports: XXX/tcp XX/tcp XXXXX/tcp protocols: masquerade: no forward-ports: source-ports: icmp-blocks: rich rules:
smtpはありますが、そのポートはTCP25だったと思います。しかしfirewallの設定リストを見ると
ports: の中に25/tcpはありませんしproduction.rbで設定したport: 587もありません。しかも
port: 587はsmtpsらしいのでservices:の項目にsmtpsがあってもいいのかと考えますが、どうなんでしょうか?
併せておしえていただけませんでしょうか?
お願いします。
追記(コンソールに出てきたlog?を追記します。)
irb(main):004:0> RegisterMailer.next_payment(user).deliver_now Rendering register_mailer/next_payment.html.erb within layouts/mailer Rendered register_mailer/next_payment.html.erb within layouts/mailer (2.0ms) Rendering register_mailer/next_payment.text.erb within layouts/mailer Rendered register_mailer/next_payment.text.erb within layouts/mailer (0.7ms) RegisterMailer#next_payment: processed outbound mail in 319.0ms Sent mail to hoge.XXXX@gmail.com (2289.6ms) Date: Tue, 21 May 2019 06:12:33 +0900 From: =?UTF-8?B?44Ov44Oz44OA44O844Ky44O844OI6YGL5Za25bGA?= To: hoge.XXXX@gmail.com Message-ID: <5ce31841da76_7683f897c9c31108046f@ik1-301-10835.vs.sakura.ne.jp.mail> Subject: =?UTF-8?Q?=E5=88=A9=E7=94=A8=E6=96=99=E9=87=91=E3=81=AE=E3=81=8A=E6=8C=AF=E3=82=8A=E8=BE=BC=E3=81=BF=E3=81=82=E3=82=8A=E3=81=8C=E3=81=A8=E3=81=86=E3=81=94=E3=81=96=E3=81=84=E3=81=BE=E3=81=99=E3=80=82?= Mime-Version: 1.0 Content-Type: multipart/alternative; boundary="--==_mimepart_5ce31841c0ac_7683f897c9c31108038d"; charset=UTF-8 Content-Transfer-Encoding: 7bit ----==_mimepart_5ce31841c0ac_7683f897c9c31108038d Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: base64 6ZW36LC36YOo5ZKM5bqD44GV44G+DQoNCuOBk+OBruW6puOBr+OAgeaciOmh jeWIqeeUqOaWmemHkeOBruOBiuaMr+OCiui+vOOBv+OBguOCiuOBjOOBqOOB huOBlOOBluOBhOOBvuOBl+OBn+OAgg0KNiDmnIjjga7jgZTliKnnlKjjgYzj gYTjgZ/jgaDjgZHjgovjgojjgYbjgavjgarjgorjgb7jgZfjgZ/jgIINCg0K 44K144Kk44OI44KS44GU5Yip55So44GE44Gf44Gg44GP44Gr44GvDQpodHRw czovL3dvbmRlci1nYXRlLmNvbQ0K44GL44KJ44Ot44Kw44Kk44Oz44KS6KGM 44Gj44Gm44GP44Gg44GV44GE44CCDQo= ----==_mimepart_5ce31841c0ac_7683f897c9c31108038d Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: base64 PCFET0NUWVBFIGh0bWw+DQo8aHRtbD4NCiAgPGhlYWQ+DQogICAgPG1ldGEg aHR0cC1lcXVpdj0iQ29udGVudC1UeXBlIiBjb250ZW50PSJ0ZXh0L2h0bWw7 IGNoYXJzZXQ9dXRmLTgiIC8+DQogICAgPHN0eWxlPg0KICAgICAgLyogRW1h aWwgc3R5bGVzIG5lZWQgdG8gYmUgaW5saW5lICovDQogICAgPC9zdHlsZT4N CiAgPC9oZWFkPg0KDQogIDxib2R5Pg0KICAgIOmVt+iwt+mDqOWSjOW6g+OB leOBvg0KPGhyIC8+DQo8cD7jgZPjga7luqbjga/jgIHmnIjpoY3liKnnlKjm lpnph5Hjga7jgYrmjK/jgorovrzjgb/jgYLjgorjgYzjgajjgYbjgZTjgZbj gYTjgb7jgZfjgZ/jgII8L3A+DQo8cD42IOaciOOBruOBlOWIqeeUqOOBjOOB hOOBn+OBoOOBkeOCi+OCiOOBhuOBq+OBquOCiuOBvuOBl+OBn+OAgjwvcD4N Cg0KPFA+44K144Kk44OI44KS44GU5Yip55So44GE44Gf44Gg44GP44Gr44Gv PGEgaHJlZj0iaHR0cHM6Ly93b25kZXItZ2F0ZS5jb20iPuOBk+OBoeOCiTwv YT7jgYvjgonjg63jgrDjgqTjg7PjgpLooYzjgaPjgabjgY/jgaDjgZXjgYTj gII8L1A+DQogIDwvYm9keT4NCjwvaHRtbD4NCg== ----==_mimepart_5ce31841c0ac_7683f897c9c31108038d-- Net::SMTPFatalError: 555 5.5.2 Syntax error. l65sm31373491pfb.7 - gsmtp

回答3件
あなたの回答
tips
プレビュー