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. 関連モジュール タイトル降順で並び替える
コンテンツの作成 7.15 Form API Validation フォームの入力内容を細かくチェックしたい
SESSION 8.9.x api $_SESION操作のAPI
アップデート 7.16 Core 7.15→7.16アップデート
リバースプロキシ 8.9.x mod_proxy mod_proxy_http mod_ssl Apache2.4 から httpsサーバーへリバースプロキシする方法
Apache2.4 7.50 Apache2.4のアクセス制限
テーマ 8.7.x Bartikのtwigについて
権限 7.50 Cron Basic認証時のCron(wget)実行方法
テーマ 8.4x hook_preprocess_html bodyタグにnode idやaliasのClassを追加する方法
Calendar 7.34 Calendar CalendarモジュールとGoogleカレンダーを同期するには
アップデート 8.9.x PHP CentosでPHPのバージョンアップ(例:5.3->5.6)を行う方法
コンテンツの作成 7.38 CKEditor CKEditorの「ソース」に入力したタグが消える
コンテンツの作成 7.31 CKEditor CKEditorの新規生成ダイアログ内の初期値の変更
コンテンツの作成 8.7.x CkEditor CKEditorエディタ内に Colorboxポップアップ を簡単に挿入する方法
コンテンツの作成 8.9.x CKEditor CKEditor編集中の見た目をフロントと全く同様にする方法
コンテンツの管理 8.6.x Commerce Commerce orderからすべての商品名を取得する方法
Libraries 8.5.x Libraries Commerceで外部JavaScriptをテスト/本番で読み分ける方法
Commerce 8.6.x Commerce Payment Order Commerceで歴代購入数/金額を集計する方法
Commerce2 8.6.x Commerce Order Commerceで注文情報から全Itemを得る方法
Commerce2 8.6.x Commerce Shipment Commerceで配送情報を得る方法
Commerce 7.34 Commerce kickstart, Commerce file Commerceモジュール利用時のダウンロード製品登録方法

ページ