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

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

ただいまの
回答率

90.22%

MediaWiki からメールが送信されない (qmail インストール時に必要な設定)

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 186

lin.ming

score 12

レンタルサーバに MediaWiki 1.32.1 をインストールしました。
特別ページ→個人設定→あなたのメールアドレスを確認→確認用コードをメールで送信
しましたが、メールが送られてきません。
というか、メール自体が送信されていません。

メール自体が送信されていないと判断した理由は、
レンタルサーバのメールログに、(スパムメールと判断されたかどうかはともかく)
メール送信ログが残っていないからです。

サーバのシェルで、例えば

$ ls-l | mail myaccount@gmail.com


を実行すると、メールログが記録されて、gmail のメールサーバにアクセスしていますから、
mail(mailx) コマンドが動作していること、MTA が正しく配送していること、
メールが送信されていること(少なくともメールを送信しようとしたこと)は確認しています。

MediaWiki は、wget で取得して、解凍して、「メインページ」にアクセスして初期設定をしたこと以外はしていません。
LocalSetting.php には、

$wgEnableEmail = true;
$wgEnableUserEmail = true; # UPO

$wgEmergencyContact = "myaccount@gmail.com";
$wgPasswordSender = "myaccount@gmail.com";

$wgEnotifUserTalk = false; # UPO
$wgEnotifWatchlist = false; # UPO
$wgEmailAuthentication = true;


と書かれていました。

MediaWiki のバージョンは 1.32.1
PHP は 7.2.9
MTA は qmail 1.03 + 色々なパッチ
OS は CentOS 7.x
です。

他に必要な項目がありましたら追記します。
よろしくお願いします。

追記
以下の php スクリプトを作りました。

<?php
mb_language("Japanese");
mb_internal_encoding("UTF-8");

$email = "myaccount@gmail.com";
$subject = "テストメール";
$body = "これはテストです。\n";
$to = "myaccount@gmail.com";
$header = "From: $email\nReplay-To: $email\n";

mb_send_mail($to, $subject, $body, $header);
?>


ブラウザからこのスクリプトにアクセスしました。
メールが送られません。(メールログに記録がありません。)
Apache のアクセスログには「"GET /mail.php HTTP/1.1" 200 -」とあるので、動作しているように思えるのですが…。

phpinfo() の結果です。
User/Group は apache(48)/48
mail.add_x_header は On
mail.force_extra_parameters は no value
mail.log は no value
SMTP は localhost
smtp_port は 25
sendmail_path は /usr/sbin/sendmail -t -i
sendmail_from は no value

他に必要な項目がありましたら追記します。

1年以上(?)前のおぼろげな記憶で質問に書けるほどの確度はないので書かなかったのですが、以前別のディレクトリにインストールした MediaWiki (v1.29 ぐらい?) では、どうもメールの確認はできていたみたいです。
今そちらで再度メール確認できるかは確認していません。

同じサーバにインストールしてある WordPress からは、コメント等が付くとこの旨メールが届いていると思います。

[root@aya ~]# ls -l /usr/sbin/sendmail*
lrwxrwxrwx 1 root root     21 Jan 28 10:54 /usr/sbin/sendmail -> /etc/alternatives/mta
-rwxr-xr-x 1 root root 247960 Oct 31  2018 /usr/sbin/sendmail.postfix
[root@aya ~]# ls -l /etc/alternatives/mta*
lrwxrwxrwx 1 root root 26 Jan 28 10:54 /etc/alternatives/mta -> /usr/sbin/sendmail.postfix
lrwxrwxrwx 1 root root 40 Jan 28 10:54 /etc/alternatives/mta-aliasesman -> /usr/share/man/man5/aliases.postfix.5.gz
lrwxrwxrwx 1 root root 22 Jan 28 10:54 /etc/alternatives/mta-mailq -> /usr/bin/mailq.postfix
lrwxrwxrwx 1 root root 38 Jan 28 10:54 /etc/alternatives/mta-mailqman -> /usr/share/man/man1/mailq.postfix.1.gz
lrwxrwxrwx 1 root root 27 Jan 28 10:54 /etc/alternatives/mta-newaliases -> /usr/bin/newaliases.postfix
lrwxrwxrwx 1 root root 43 Jan 28 10:54 /etc/alternatives/mta-newaliasesman -> /usr/share/man/man1/newaliases.postfix.1.gz
lrwxrwxrwx 1 root root 23 Jan 28 10:54 /etc/alternatives/mta-pam -> /etc/pam.d/smtp.postfix
lrwxrwxrwx 1 root root 22 Jan 28 10:54 /etc/alternatives/mta-rmail -> /usr/bin/rmail.postfix
lrwxrwxrwx 1 root root 25 Jan 28 10:54 /etc/alternatives/mta-sendmail -> /usr/lib/sendmail.postfix
lrwxrwxrwx 1 root root 41 Jan 28 10:54 /etc/alternatives/mta-sendmailman -> /usr/share/man/man1/sendmail.postfix.1.gz


あれ?なんで Postfix?

あれ? Postfix を追い出して qmail インストールしたんだから

# ln -s /var/qmail/bin/sendmail /usr/sbin/sendmail


じゃないといけないですよね?

  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • CHERRY

    2019/05/20 22:21 編集

    php から、/usr/sbin/sendmail 経由で、 /usr/sbin/sendmail.postfix が、動いているとしたら、 /var/log/maillog に記録が残っていると思いますが、なにかログは、残っていますか?

    /var/log/maillog に spool への保存のログ残っているとしたら、Postfix で送信しようとしていると思いますので、 qmail の sendmail からシンボリックリンクを貼り直すとどうなりますか?

    キャンセル

  • lin.ming

    2019/05/21 11:09

    シンボリックリンクを qmail のに張り替えたら無事に確認メールが届くようになりました。
    ありがとうございます。
    CHERRY さんをベストアンサーに選びたいのですが。

    キャンセル

  • CHERRY

    2019/05/21 11:29

    確認してほしい箇所を指摘しただけなので「自己解決」で大丈夫だと思うのですが、お言葉に甘えて「質問への追記・修正の依頼」のやり取りをまとめ直して、回答欄に記載しておきます。

    キャンセル

回答 1

checkベストアンサー

+1

「質問への追記・修正の依頼」のやり取りをまとめ直して記載しておきます。


質問内容(問題点): 

  • Mediawiki からメールができない。( PHP からメールが送信できない )
  • MTA は、 qmail 使用。

確認を依頼した内容

  • php の mail() 関数でメールが送信できるか?
  • phpinfo() で、php.ini のメール関連の設定を確認する。( Linux 等では、 sendmail_path に指定した sendmail コマンドが使われる。 )
  • メールのログの確認。 ( /var/log/maillog を確認して、postfix の sendmail コマンドが実際に使われているかの確認 )

確認・対応していただいた内容

  1. sendmail_path に指定された sendmail コマンド( /usr/sbin/sendmail ) を確認すると現在使用していない Postfix の sendmail コマンドになっていた。
  2. /usr/sbin/sendmail を qmail の sendmail コマンド( /var/qmail/bin/sendmail ) のシンボリックリンクに変更することで解決した。
    ( 別の対処方法としては、 php.ini の sendmail_path の設定を /var/qmail/bin/sendmail に変更して PHP を再起動でも OK )

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/05/21 11:31

    すごく参考になりました。
    ありがとうございました。

    キャンセル

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

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