![]() |
![]() |
![]() |
milter managerリファレンスマニュアル | ![]() |
---|
CentOSに特化したmilter managerのインストール方法について説明します。CentOSに依存しない一般的なインストール情報は インストール を見てください。
CentOSのバージョンは5.3を想定しています。また、root権限での実行はsudoを使用することを想定しています。sudoを利用していない場合はsuなどroot権限で実行してください。
以下のパッケージをインストールすることにより、関連するパッケージもインストールされます。
% sudo yum install -y libtool intltool gcc glib2-devel ruby ruby-devel
MTAは標準でインストールされているSendmailを利用することとします。
% sudo yum install -y sendmail-cf
milterはspamass-milter、clamav-milter、milter-greylistを使用することとします。各milterはRPMforgeにあるものを利用します。
32bit環境の場合は以下のようにRPMforgeを登録します。
% wget http://packages.sw.be/rpmforge-release/rpmforge-release-0.3.6-1.el5.rf.i386.rpm % sudo rpm -Uhv rpmforge-release-0.3.6-1.el5.rf.i386.rpm
64bit環境の場合は以下のようにRPMforgeを登録します。
% wget http://packages.sw.be/rpmforge-release/rpmforge-release-0.3.6-1.el5.rf.x86_64.rpm % sudo rpm -Uhv rpmforge-release-0.3.6-1.el5.rf.x86_64.rpm
RPMforgeを登録したらmilterをインストールします。
% sudo yum install -y spamass-milter clamav-milter milter-greylist
また、グラフ作成用にRRDtoolもインストールします。
% sudo yum install -y ruby-rrdtool
milter managerはRPMパッケージが用意されていますが、依存関係の問題でyumではインストールできません。そのため、手動でRPMパッケージをインストールします。
Ruby/GLib2 0.17以降ではRuby 1.8.5はサポートされていないため、Ruby/GLib2 0.16.0を使います。 電脳Rubyプロジェクト が提供しているRuby/GLib2のパッケージを利用します。
32bit環境の場合:
% wget http://dennou-k.kugi.kyoto-u.ac.jp/arch/ruby/products/rpm/RPMS/CentOS/5/i386/ruby-glib2-0.16.0-1dc.i386.rpm % sudo rpm -Uvh ruby-glib2-0.16.0-1dc.i386.rpm
64bit環境の場合:
% wget http://dennou-k.kugi.kyoto-u.ac.jp/arch/ruby/products/rpm/RPMS/CentOS/5/x86_64/ruby-glib2-0.16.0-1dc.x86_64.rpm % sudo rpm -Uvh ruby-glib2-0.16.0-1dc.x86_64.rpm
32bit環境の場合:
% wget http://downloads.sourceforge.net/milter-manager/milter-manager-1.4.0-0.i386.rpm % sudo rpm -Uvh milter-manager-1.4.0-0.i386.rpm
64bit環境の場合:
% wget http://downloads.sourceforge.net/milter-manager/milter-manager-1.4.0-0.x86_64.rpm % sudo rpm -Uvh milter-manager-1.4.0-0.x86_64.rpm
milterの基本的な設定方針は以下の通りです。
接続はIPv4ソケットでローカルホストからのみ接続を受け付けるようにします。
必要のない配送遅延をできるだけ抑えるため、milter-greylistは S25R にマッチするときのみ適用します。しかし、これはmilter-managerが自動で行うため、特に設定する必要はありません。
まず、spamdの設定をします。
デフォルトの設定ではスパム判定されたメールは件名に「[SPAM]」が追加されます。もし、これが嫌な場合は/etc/mail/spamassassin/local.cfを以下のように変更します。
変更前:
rewrite_header Subject [SPAM]
変更後:
# rewrite_header Subject [SPAM]
また、スパム判定された場合のみ、その詳細をヘッダに追加するようにする場合は以下を追加します。
remove_header ham Status remove_header ham Level
システム起動時にspamdを起動するようにします。
% sudo /sbin/chkconfig spamassassin on
spamdを起動します。
% sudo /sbin/service spamassassin start
spamass-milterはソケットを変更します。
/etc/sysconfig/spamass-milterに以下を追加します。
SOCKET="inet:11120@[127.0.0.1]"
システム起動時にspamass-milterを起動するようにします。
% sudo /sbin/chkconfig spamass-milter on
spamass-milterを起動します。
% sudo /sbin/service spamass-milter start
clamdを起動します。
% sudo /sbin/service clamd start
clamav-milterのソケットを変更します。
/etc/clamav-milter.confを以下のように変更します。
変更前:
MilterSocket unix:/var/clamav/clmilter.socket
変更後:
MilterSocket inet:11121@[127.0.0.1]
clamav-milterを起動します。
% sudo /sbin/service clamav-milter start
/etc/mail/greylist.confを編集し、デフォルトでGreylistを使うようにします。
変更前:
racl whitelist default
変更後:
racl greylist default
次に、以下の内容の/etc/sysconfig/milter-greylistを作成します。
OPTIONS="$OPTIONS -p inet:11122@[127.0.0.1]"
システム起動時にmilter-greylistを起動するようにします。
% sudo /sbin/chkconfig milter-greylist on
milter-greylistを起動します。
% sudo /sbin/service milter-greylist start
milter-managerはシステムにインストールされているmilterを検出します。以下のコマンドでspamass-milter、clamav-milter、milter-greylistを検出していることを確認してください。
% sudo /usr/sbin/milter-manager -u milter-manager --show-config
以下のように表示されていれば検出は成功しています。
... define_milter("milter-greylist") do |milter| milter.connection_spec = "inet:11122@[127.0.0.1]" ... milter.enabled = true ... end ... define_milter("clamav-milter") do |milter| milter.connection_spec = "inet:11121@[127.0.0.1]" ... milter.enabled = true ... end ... define_milter("spamass-milter") do |milter| milter.connection_spec = "inet:11120@[127.0.0.1]" ... milter.enabled = true ... end ...
milterの名前、ソケットのパス、enabledがtrueになっていることを確認してください。異なっていた場合は、 設定 を参考に/etc/milter-manager/milter-manager.confを編集してください。ただ、できれば、設定を変更せずに使用できるようにしたいと考えています。もし、検出できなかった環境のことを教えてもらえれば、milter-manager.confを編集しなくとも使用できるように検出方法を改良することができるかもしれません。
milter-managerの設定が完了したので、起動します。
% sudo /sbin/service milter-manager restart
milter-test-serverで起動の確認をすることができます。
% sudo -u milter-manager milter-test-server -s unix:/var/run/milter-manager/milter-manager.sock
このように表示されれば成功です。
status: pass elapsed-time: 0.128 seconds
起動に失敗しているときはこのように表示されます。
Failed to connect to unix:/var/run/milter-manager/milter-manager.sock
失敗している時はログを頼りに問題を解決します。--verboseオプションをつけると詳細なログが表示されます。また、デーモンプロセスにしないことにより、標準出力にもログが表示されます。
/etc/sysconfig/milter-managerに以下の内容を追加します。これにより、標準出力に詳細なログが表示されます。
OPTION_ARGS="--verbose --no-daemon"
milter-managerをもう一度起動します。
% sudo /sbin/service milter-manager restart
問題があればログが表示されます。起動しているmilter-managerはCtrl+cで終了することができます。
問題が解決した後は、/etc/sysconfig/milter-managerに追加したOPTION_ARGSをコメントアウトし、デーモンプロセスで起動するように戻してから、milter-managerを起動しなおしてください。
まず、Sendmailを有効にします。
% sudo /sbin/chkconfig --add sendmail % sudo /sbin/service sendmail start
Sendmailにmilter-managerを登録するために、/etc/mail/sendmail.mcに以下を追加します。
INPUT_MAIL_FILTER(`milter-manager', `S=local:/var/run/milter-manager/milter-manager.sock')
spamass-milter、clamav-milter、milter-greylistはmilter-manager経由で利用するので、Sendmailにはmilter-managerだけを登録すればよいことに注意してください。
Sendmailの設定を更新し、再読み込みします。
% sudo make -C /etc/mail % sudo /sbin/service sendmail reload
以上で設定は完了です。
milter-managerはいくつかsyslogにログを出力します。mail.infoに出力するので、正常に動作していればmilter-managerからのログが/var/log/maillogにログがでるはずです。テストメールを送信して確認してください。
milter-managerを導入することにより、milterとSendmailを連携させる手間が削減されています。
通常であれば、sendmail.mcにspamass-milter、clamav-milter、miler-greylistのそれぞれのソケットを指定する必要があります。しかし、milter-managerを導入することにより、milter-managerのソケットのみを指定するだけですむようになりました。各milterのソケットはmilter-managerが検出するため、typoなどの小さいですが気づきにくいミスに惑わされることがなくなります。
また、ここでは触れませんでしたが、milter-managerは/sbin/chkconfig --addされているかどうかも検出します。そのため、milterを無効にしたい場合は、他のサービスと同様に以下のような手順になります。
% sudo /sbin/service milter-greylist stop % sudo /sbin/chkconfig --del milter-greylist
milterを無効にしたら、milter-managerの設定を再読み込みします。milter-managerはmilterが無効になったことを検出し、無効になったmilter とは接続しなくなります。
% sudo /sbin/service milter-manager reload
Sendmailのsendmail.mcを変更する必要はありません。
CentOS上でmilterを複数使っている場合は、milter-managerを導入して、管理コストを削減することができます。