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. 関連モジュール タイトル
開発 mail 7.50 Mail Safety 開発/テスト用サイトのメール
言語 7.28 vim vimで全角が化けてしまう
言語 7.15 Entity Translation デフォルトの言語 - Entity Translation
言語 6.x i18n 多言語対応サイトのサイト名やスローガン/ミッションなどを多言語化する方法を教えてください
言語 7.15 Entity Translation 各フィールドのラベルの多言語切り替え漏れ(フィールド・ラベル)
言語 7.15 Entity Translation nodeのEntity Translation
言語 7.15 Language まだ翻訳されていない英語文、どうにかならない?
言語 7.14 Entity Translation 各フィールドのラベルの多言語切り替え漏れ(接頭子、接尾子)
言語 6.22 URLエイリアスを使った場合に、翻訳したページで同じURLエイリアスが使えないという不具合
見栄え 7.15 js Injector 簡単にJavascriptを追加する方法は?
表示 7.26 Views ページ内に2つ目Viewsブロックを設置するときPagerが連動してしまう
表示 7.34 Views Infinite Scroll Facebookページのようにスクロールするとコンテンツが追加されるようなコントロール
権限 7.15 Path_Access Content_Access 特定のページ(パス)をアクセス制限したい
権限 7.50 Cron Basic認証時のCron(wget)実行方法
排他 7.26 lock Viewsモジュールの設定ページのような排他機能
拡張機能 8.3x Contribute modules drupal8-寄贈モジュールの動向
ログイン 8.7.x System ユーザー アカウントロックの範囲設定
リバースプロキシ 8.9.x mod_proxy mod_proxy_http mod_ssl Apache2.4 から httpsサーバーへリバースプロキシする方法
ユーザの管理 8.9.x user pass drupal 8 で 管理者(uid=1)パスワードがわからなくなったとき 新しいパスワードを設定する方法
ユーザの管理 7.15 Devel 簡単に指定ユーザにログインしなおす方法

ページ