2008/05/08(木)[debian] qmail + smtp_auth(qmail-vida) + pop3
インストール前に
現在動いているexim4を止めて起動しないようにする.
teapopも一緒に止める.必要ならinetdにHUPシグナルを送って再起動.
# /etc/init.d/exim4 stop # update-rc.d -f exim4 remove # /etc/init.d/teapop stop # update-rc.d -f teapop remove # vi /etc/inetd.conf # kill -HUP `ps -C inetd | grep inetd | awk '{print $1;}'`
ダウンロード
ソースを落として解凍.
$ wget http://qmail.org/netqmail-1.06.tar.gz $ wget http://jaist.dl.sourceforge.jp/qmail-vida/2100/qmail-vida-0.53.tar.gz $ wget http://cr.yp.to/ucspi-tcp/ucspi-tcp-0.88.tar.gz $ wget http://cr.yp.to/checkpwd/checkpassword-0.90.tar.gz $ tar xvzf netqmail-1.06.tar.gz $ tar xvzf qmail-vida-0.53.tar.gz $ tar xvzf ucspi-tcp-0.88.tar.gz $ tar xvzf checkpassword-0.90.tar.gz
コンパイル前に
qmail-vidaを解凍して出てきたdoc/install.htmlを参考にしてます.
Makefileの修正とパッチ当て
$ cd qmail-vida-0.53 $ vi Makefile $ diff Makefile.org Makefile 1c1 < QMAILSRC = ../qmail-1.03 --- > QMAILSRC = ../netqmail-1.06 43c43 < ${PATCH} -p1 < $${here}/patch/qmail.patch --- > ${PATCH} -p1 -F 3 < $${here}/patch/qmail.patch $ make patch $ make copy $ cd ../checkpassword-0.90 $ patch -p1 < ../netqmail-1.06/other-patches/checkpassword-0.90.errno.patch $ cd ../ucspi-tcp-0.88/ $ patch -p1 < ../netqmail-1.06/other-patches/ucspi-tcp-0.88.errno.patch
グループとユーザの追加
仮想メールボックスは/var/vboxに置くようにしています.
グループ名,ユーザ名を変更する場合は各パッケージのconf-*を適宜変更します.
# groupadd -g 500 vida # useradd -d /var/vbox -g vida -u 500 pop # useradd -d /var/qmail/authdb -g vida -u 501 -s /bin/false authdb # useradd -d /var/qmail/qmailu -g vida -u 502 -s /bin/false qmailu # groupadd -g 501 nofiles # useradd -g nofiles -u 503 -d /var/qmail/alias alias # useradd -g nofiles -u 504 -d /var/qmail qmaild # useradd -g nofiles -u 505 -d /var/qmail qmaill # useradd -g nofiles -u 506 -d /var/qmail qmailp # groupadd -g 502 qmail # useradd -g qmail -u 507 -d /var/qmail qmailq # useradd -g qmail -u 508 -d /var/qmail qmailr # useradd -g qmail -u 509 -d /var/qmail qmails
コンパイルとインストール
# cd netqmail-1.06 # make setup check # cd ../checkpassword-0.90 # make # make setup check # cd ../ucspi-tcp-0.88/ # make # make setup check # cd ../qmail-vida-0.53/src/vida # make # make setup check # cd ../../ # make install-doc
設定
初期設定
popで平文通すために
# cd netqmail-1.06 # config-fast mail.hoge.com # /var/qmail/bin/vida-pwdbinit # vi /usr/local/etc/pop3.rul # cat /usr/local/etc/pop3.rul :allow,ALLOWPLAIN="",DOMAINOWNER="" # tcprules /usr/local/etc/pop3.cdb /usr/local/etc/pop3.tmp < /usr/local/etc/pop3.rul
起動スクリプト
起動のみです.終了部は書いてませんのでだまされないように(汗)
qmail
#!/bin/sh HOST="hoge.com" PATH=/var/qmail/bin:/usr/local/bin:/usr/bin:/bin case "$1" in start) # Start daemons. echo "Starting qmail:" exec env - PATH="$PATH" qmail-start ./Maildir/ splogger qmail & exec env - PATH="$PATH" DOMAINOWNER="pop" \ tcpserver -vHR -l"$HOST" -- 0 587 fixcrio \ qmail-smtpup "$HOST" checkpassword qmail-smtpd 2>&1 | \ splogger smtpd & ;; stop) # Stop daemons. ;; *) echo "Usage: qmail {start}" exit 1 esac exit 0
pop
#!/bin/sh HOST="hoge.com" PATH=/var/qmail/bin:/usr/local/bin:/usr/bin:/bin case "$1" in start) # Start daemons. echo "Starting qmail-popd:" exec env - PATH="$PATH" DOMAINOWNER="pop" \ tcpserver -vHR -l"$HOST" -x /usr/local/etc/pop3.cdb -- 0 110 \ qmail-popup "$HOST" checkpassword qmail-pop3d Maildir 2>&1 | \ splogger pop3d & ;; *) echo "Usage: pop3 {start}" exit 1 esac exit 0
動作確認
以下はmailtestというユーザを作成してテストしています.
Maildirの作成
$ cd $ /var/qmail/bin/maildirmake Maildir
パスワードの設定
ここで設定したパスワードをsmtp, pop3で利用します.
例では testpassword というパスワードを設定しています.
$ /var/qmail/bin/vida-passwd New password: testpassword Retype new password: testpassword
接続
SMTPから
$ telnet localhost 587 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. 220 mail.hoge.com ESMTP EHLO localhost 250-mail.hoge.com 250-AUTH CRAM-MD5 250 8BITMIME auth cram-md5 334 PDI2NDk2LjEyMTAyNDg1NTJAcGMxNy5tYWViYXNoaS1pdC5vcmc+ bWFpbHRlc3QgOTRkN2QwMzU2ZDgzYjFmYTJjNDc2NTU4Nzg3OTQ3Y2E= 235 ok, go ahead (#2.0.0) MAIL FROM: mailtest@localhost 250 ok RCPT TO: mailtest@mail.hoge.com 250 ok DATA 354 go ahead Subject: test mail this is test mail . 250 ok 1210248605 qp 26499 quit 221 mail.hoge.com Connection closed by foreign host.
cram-md5の認証に関しては以下のスクリプトを参考にさせて頂きました.
http://nai.homelinux.net/telnet_smtp_auth.html
続いてpop
$ telnet localhost 110 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. +OK <26541.1210248810@mail.hoge.com> USER mailtest +OK PASS testpassword +OK LIST +OK 1 403 . RETR 1 +OK Return-Path: <mailtest@localhost> Delivered-To: mailtest@mail.hoge.com Received: (qmail 26499 invoked from network); 8 May 2008 12:09:56 -0000 X-Authentication: mailtest was authenticated by mail.hoge.com at 8 May 2008 12:09:56 -0000 Received: from unknown (HELO localhost) (127.0.0.1) by mail.hoge.com with SMTP; 8 May 2008 12:09:56 -0000 Subject: test mail this is test mail . quit +OK Connection closed by foreign host.
APOP対応なのに使ってないワナ.
とりあえずインストールしてみただけなのでそのうちexim4に戻す予定.