mail()での送信が失敗する

カテゴリ フォーム コアバージョン 7.15 関連モジュール system

メール送信ができない事があった場合、これをチェックしましょう。

コメント

ユーザー actbrain の写真

サーバーの設定のよっては、drupalのせいではなく、mail()関数によるメール送信が出来ない状況に置かれる事があります。
例えば、簡単な例題スクリプト)
<?php
// 本文
$message = "Line 1\nLine 2\nLine 3";

// 1 行が 70 文字を超える場合のため、wordwrap() を用いる
$message = wordwrap($message, 70);

// 送信する
echo mail('user1@act-brain.co.jp', 'My Subject', $message)? 'Success': 'Fail';
?>
なようなものを作成して事項してみてもメールが飛ばない場合、
そして、maillog内に
「postfix/sendmail[12934]: fatal: chdir /var/spool/postfix: Permission denied」というような記述があったら、selinuxを疑ってみます。

SSHより
# setenforce 0
一時的にselinuxを無効にしたうえで再度上記例題スクリプトを実行してみましょう。
これでメールが飛んだら、selinuxのせいです。
上記のコマンドはselinuxを一時的に無効にしているだけなので、サーバーが再起動した場合、元に戻ってしまいます。

恒久的な対処としては、
/etc/selinux/config 内の 動作モードに関する記述を変更する必要があります。
SELINUX=enforcing

SELINUX=permissive

上記の対処は、SELINUXが必要ない場合の処置です。
何らかの形でSELINUXが必要な場合は、上記対処は不適切です。状況に応じた設定変更が必要になります。

ユーザー actbrain の写真

SELinuxを有効にしたまま、メール送信のみ許可するには以下設定になります。

# setenforce 1 …SELinuxを有効化
# getsebool httpd_can_sendmail
httpd_can_sendmail --> off  …パラメータ確認
# setsebool -P httpd_can_sendmail on …パラメータ変更
# getsebool httpd_can_sendmail
httpd_can_sendmail --> on  …パラメータ変更確認

ページ

OTHER FAQ

Drupal開発・運用の疑問/質問の答えはここに

無料ユーザー登録すると質問できます。

カテゴリ Core Ver.降順で並び替える 関連モジュール タイトル
アップデート 8.8.x Composer composer updateが異常終了する
アップデート 8.9.x Composer update Composer で drupal/core-8.9.7 に更新できなくなった場合の処置
コンテンツの作成 8.9.x CSS キャプション付きの(右寄/左寄)画像を画像サイズを基準にきれいに表示する方法
リバースプロキシ 8.9.x mod_proxy mod_proxy_http mod_ssl Apache2.4 から httpsサーバーへリバースプロキシする方法
アップデート 8.9.x PHP CentosでPHPのバージョンアップ(例:5.3->5.6)を行う方法
テーマ 8.9.x Twig Twig で 月末日を算出する方法
テーマ 8.9.x patch パッチ 開発環境のファイル変更を本番環境にパッチでデプロイする方法(画像含まず)
ユーザの管理 8.9.x user pass drupal 8 で 管理者(uid=1)パスワードがわからなくなったとき 新しいパスワードを設定する方法
テーマ 8.9.x スマホに向いたテーマについて
コンテンツの作成 8.9.x Display sweet, Views, Twig Tweak, Views field formatter テーマに頼らず コンテンツのフィールドとしてViewsを埋め込み表示する方法
サイトの構築 8.9.x Webform drupalを使用した登録、一覧表示の方法について
アップデート 8.9.x Composer update composer update するときに パッチが必要なモジュールが更新されパッチが消えてしまうことへ対応する方法
サイト情報 8.9.x api Drupal::request() メモ
フォーム 8.9.x api GET/POSTされた情報を得る方法
コンテンツの管理 8.9.x 写真の変更を行いたい
フォーム 8.9.x Views Views exposed filterのフォームに#default_valueを仕込む方法
コンテンツの管理 8.9.x Dialog Modal Canvas drupal 8 の標準機能のダイアログ/ポップアップを表示する方法
PHP-FPM 8.9.x PHP PHP-FPM 環境で .htaccess に php_value を 書いてもダメ
コンテンツの作成 8.9.x CKEditor CKEditor編集中の見た目をフロントと全く同様にする方法
コンテンツの作成 8.9.x node ノード保存時の前回値の参照方法

ページ