質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.77%

Railsで500 Internal Server Errorが発生してしまい原因がわからずに困っています。

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 3,260

koume

score 164

開発環境では問題無かったのですが、デプロイ後に動作確認したところ「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
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • suama

    2019/05/20 21:27 編集

    user = Customer.find(2) で送信先のユーザのメールアドレスが本番と開発で同じ値が入っていて間違いないとしたら、たとえば from: (送信元)のほうが適切でないメールアドレスになっていませんでしょうか?
    productionとdevelopmentで from: が変わるような構成とか。
    (default from: '運営局' ではなくて default from: "organizer@example.com" とかだとは思いつつ、たぶんそこは記載上そうしているかと思いますが)

    (追記です)
    From: にメールドレスが入っていないような気がしますが、間違いはないでしょうか?
    From: "xxx運営局" <xxx-organizer@example.com> とか
    From: xxx-organizer@example.com
    になるのが正しそうですが、"xxx運営局" といいう名称しか入っていないようです。

    キャンセル

  • CHERRY

    2019/05/21 09:16 編集

    to: suama さん

    From は、 https://tools.ietf.org/html/rfc5322#section-3.4 に書かれているとおり、名前部分は省略できますが、addr-spec ( メールアドレス )は省略できないので、メールアドレスがないとエラーの原因になりそうです。

    回答欄に書きませんか? > suama さん


    to: koume さん

    Gmail 経由で送信する場合、送信するメールの From アドレスが、 gmail.com 以外の場合は、Gmail に追加して確認済みのメールアドレスしか使えませんので、From で使っているアドレスがGmail以外の場合は確認済みになっているかを確認してください。

    キャンセル

  • suama

    2019/05/21 12:38

    CHERRYさん、ありがとうございます!了解しました!

    キャンセル

回答 3

+1

エラーが

Net::SMTPFatalError: 555 5.5.2 Syntax error. u38sm41434419pgn.73 - gsmtp

ということは、gmail のサーバーまでは通信できていて、 gmail の SMTP サーバーにデータを送信した際に 「250 OK」ではなく、「555 5.5.2 Syntax error」が返ってきたということです。

503, 530, 535 ではないので、おそらく認証は通っていると考えられます。( gmail には、ステータスに関するヘルプがないので参考ですが、SMTP エラー リファレンス - G Suite 管理者ヘルプ 参照。)

「555 5.5.2 Syntax error」の場合は、メールヘッダかメールボディが、 RFC 5322 や RFC 6854 で決められた書式を守っていない可能性が高いです。

原因の可能性としては、たとえば、

  • コントロールコードの混入
  • メールヘッダには、US-ASCII しか使えないが、日本語等が正しくエンコーディングされていない
  • 文字数オーバー 
    etc...

いろいろあるので、メールの送信のログを取りながらデバッグしてみてください。

Rails でメールのログは、

ActionMailer の送信ログをとりたい
開発中にrailsから送信したメールを確認する

等を参照してください。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/05/21 06:41

    コンソールでメール送信を実行したときにでてきた内容を追記させていただきました。
    よくわからないのですが最初の----==_mimepart_5ce31841c0ac_7683f897c9c31108038dのところで
    htmlファイルを読み込み2回目のところでtext.htmlを読み込み3回目のところでエラーが発生しています。
    ということは自分の設定だとRegisterMailerのnext_paymentアクションを呼び
    next_payment.html.erbとnext_payment.text.erbの読み込みまでは成功し
    アクション内のmail to: user.emailでそのアドレスに送信しようとしてエラーが発生した。
    ということなのでしょうか?だとすると間違ったアドレスということなのでしょうか?
    見当違いな解釈かもしれませんが、宜しくお願いします。

    キャンセル

  • 2019/05/22 12:38

    CHERRY様、まだ解決できずにいますが、さくらのVPSのpostfixの設定についてなにも編集していないので
    それが影響しているとかあるのでしょうか?
    postfixにドメイン名の設定とかhost nameの設定などの記事をつけたので気になっていますが
    それが原因なのでしょうか?

    キャンセル

  • 2019/05/25 19:54

    いつも、詳しい回答ありがとうございます。
    postfixの設定を何もしていなかったので、もしかしたらそれが原因かもしれないのでpostfixの
    学習をして、改めて実行してみます。

    キャンセル

+1

こんにちは。質問者さま、何回か追記、質問をさせていただきました。ありがとうございます!
また、CHERRYさま、誘導してくださってありがとうございます。

回答というほどにはならないかもしれませんが、念のため、From / To: として実際に入ってくる値が、正しいメールアドレス形式になっているかもご確認ください。

From: =?UTF-8?B?44Ov44Oz44OA44O844Ky44O844OI6YGL5Za25bGA?=
To: hoge-example@gmail.com

の部分は、デコードすると 「xxx運営局」になっていて、xxx@example.com や "xxx運営局" <xxx@example.com> になっていないので、そこでエラーになっているかもしれません。

Fromやその他のメールヘッダが環境変数(RAILS_ENV) に応じて調整されるようになっていたら、development環境では正しくメールが送れたのに、本番でNGだとすると、このあたりの値が気になるかなと思います。
通信上のエラーだともっと違うメッセージが出そうな気はします。
CCで連結とか、環境変数で切り替えとかの場合、なにかゴミが入ってるかもしれません。

rails consoleでも確認されているかと思いますが、メール送信は外に出るものなので、慎重に確認するに越したことはないと思います。
上手くいくといいですね。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/05/25 19:52

    回答ありがとうございます。
    postfixの設定をなにもしていないので、そこが原因かもしれないので設定を見直した後で
    試してみることにします。

    キャンセル

check解決した方法

-1

いろいろ試してみましたが、解決に至りませんでした。
もしかしたらpostfixをインストールしっぱなしで設定していないのが原因かもしれないので
設定の学習をして試してみたいと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る