メールサーバー · 2 min read · Oct 14, 2025
Postfix、Courier、MySQL、SquirrelMailを使用した仮想ユーザーとドメイン (Debian Wheezy)
このチュートリアルはFalko Timmeによる著作権(c) 2013です。これはChristoph Haasのチュートリアルに基づいており、http://workaround.orgで見つけることができます。このチュートリアルは、Creative Commonsライセンス2.5またはそれ以降のバージョンの下で自由に使用できます。
この文書では、MySQLデータベースにある仮想ユーザーとドメインに基づいたPostfixメールサーバーのインストール方法を説明します。また、Courier(Courier-POP3、Courier-IMAP)のインストールと設定も示し、CourierがPostfixが使用するのと同じMySQLデータベースに対して認証できるようにします。
結果として得られるPostfixサーバーは、SMTP-AUTH、TLS、およびクォータに対応しています(クォータはデフォルトではPostfixに組み込まれていませんので、適切にPostfixをパッチする方法を示します)。パスワードはデータベースに暗号化された形式で保存されます(私が見つけたほとんどの文書はプレーンテキストのパスワードを扱っており、これはセキュリティリスクです)。さらに、このチュートリアルでは、スパムとウイルスのスキャンのためにAmavisd、SpamAssassin、およびClamAVのインストールもカバーします。また、ユーザーがメールを読み、送信し、パスワードを変更できるようにするために、SquirrelMailをWebメールインターフェースとしてインストールする方法も示します。
このような「仮想」セットアップ(MySQLデータベース内の仮想ユーザーとドメイン)の利点は、「実際の」システムユーザーに基づくセットアップよりもはるかにパフォーマンスが良いことです。この仮想セットアップを使用すると、メールサーバーは数千のドメインとユーザーを処理できます。さらに、新しいユーザー/ドメインを追加したり、既存のものを編集したりする際にMySQLデータベースだけを扱えばよいので、管理が容易です。dbファイルを作成するためのpostmapコマンドは不要で、Postfixの再読み込みも不要です。MySQLデータベースの管理には、phpMyAdminのようなWebベースのツールを使用できます。このhowtoでもインストールされます。3つ目の利点は、ユーザーがユーザー名としてメールアドレスを持つこと(ユーザー名+メールアドレスではなく)で、理解しやすく、記憶しやすいことです。
このhowtoは実用的なガイドとして意図されています。理論的な背景はカバーしていません。それらはWeb上の他の多くの文書で扱われています。
この文書は、いかなる種類の保証もなく提供されます!このシステムを設定する唯一の方法ではないことを言いたいです。この目標を達成する方法はたくさんありますが、これは私が取る方法です。これがあなたにとって機能することを保証するものではありません!
1 前提条件
このチュートリアルはDebian Wheezyに基づいているため、このチュートリアルを続ける前に基本的なDebian Wheezyサーバーのインストールを設定する必要があります。システムには静的IPアドレスが必要です。このチュートリアルでは192.168.0.100をIPアドレスとして使用し、server1.example.comをホスト名として使用します。
/bin/shを/bin/bashへのシンボリックリンクにすることが非常に重要です…
dpkg-reconfigure dashdashをデフォルトのシステムシェル(/bin/sh)として使用しますか? <– いいえ
… そして、AppArmorを無効にします:
/etc/init.d/apparmor stop
update-rc.d -f apparmor remove
apt-get remove apparmor apparmor-utils2 Postfix、Courier、Saslauthd、MySQL、phpMyAdminのインストール
Postfix、Courier、Saslauthd、MySQL、およびphpMyAdminをインストールするには、単に次のコマンドを実行します。
apt-get install postfix postfix-mysql postfix-doc mysql-client mysql-server courier-authdaemon courier-authlib-mysql courier-pop courier-pop-ssl courier-imap courier-imap-ssl libsasl2-2 libsasl2-modules libsasl2-modules-sql sasl2-bin libpam-mysql openssl phpmyadmin apache2 libapache2-mod-php5 php5 php5-mysql libpam-smbpassいくつかの質問が表示されます:
一般的なメール構成のタイプ: <– インターネットサイト
システムメール名: <– server1.example.com
MySQL「root」ユーザーの新しいパスワード: <– yourrootsqlpassword
MySQL「root」ユーザーのパスワードを再入力: <– yourrootsqlpassword
Webベースの管理用にディレクトリを作成しますか? <– いいえ
SSL証明書が必要ですか <– はい
自動的に再構成するWebサーバー: <– apache2
phpmyadmin用のデータベースをdbconfig-commonで構成しますか? <– いいえ
3 Postfixにクォータパッチを適用
Postfixのソースを取得し、クォータパッチでパッチを当て、新しいPostfix.debパッケージをビルドしてインストールする必要があります:
apt-get build-dep postfixcd /usr/src
apt-get source postfix(次のコマンドで正しいPostfixバージョンを使用していることを確認してください。私はPostfix 2.9.6をインストールしています。次のコマンドを実行してPostfixのバージョンを確認できます。
postconf -d | grep mail_version出力は次のようになります:
root@server1:/usr/src# postconf -d | grep mail_version
mail_version = 2.9.6
milter_macro_v = $mail_name $mail_version
root@server1:/usr/src#)
wget http://vda.sourceforge.net/VDA/postfix-vda-v11-2.9.6.patch
cd postfix-2.9.6
patch -p1 < ../postfix-vda-v11-2.9.6.patch次に、debian/rulesを開き、DEB_BUILD_HARDENINGを1から0に変更します:
vi debian/rules| [...] export DEB_BUILD_HARDENING=0 [...] |
これを行わないと、次のエラーメッセージでビルドが失敗します:
maildir.c: In function âdeliver_maildirâ:
maildir.c:974:17: error: format not a string literal and no format arguments [-Werror=format-security]
maildir.c:977:17: error: format not a string literal and no format arguments [-Werror=format-security]
maildir.c:983:17: error: format not a string literal and no format arguments [-Werror=format-security]
maildir.c:986:17: error: format not a string literal and no format arguments [-Werror=format-security]
maildir.c: In function âsql2fileâ:
maildir.c:404:25: warning: ignoring return value of âreadâ, declared with attribute warn_unused_result [-Wunused-result]
maildir.c:417:26: warning: ignoring return value of âwriteâ, declared with attribute warn_unused_result [-Wunused-result]
cc1: some warnings being treated as errors
make: * [maildir.o] Error 1
make: Leaving directory `/usr/src/postfix-2.9.3/src/virtual'
make[1]: * [update] Error 1
make[1]: Leaving directory `/usr/src/postfix-2.9.3'
make: *** [build] Error 2
dpkg-buildpackage: error: debian/rules build gave error exit status 2
root@server1:/usr/src/postfix-2.9.3#新しいPostfix.debパッケージをビルドできます:
dpkg-buildpackage次に、1つ上のディレクトリに移動します。そこに新しい.debパッケージが作成されています:
cd ..コマンド
ls -lは、利用可能なパッケージを表示します:
root@server1:/usr/src# ls -l
total 8400
drwxr-xr-x 4 root root 4096 May 7 01:24 linux-headers-3.2.0-4-amd64
drwxr-xr-x 4 root root 4096 May 7 01:24 linux-headers-3.2.0-4-common
lrwxrwxrwx 1 root root 23 Jun 24 2012 linux-kbuild-3.2 -> ../lib/linux-kbuild-3.2
drwxr-xr-x 18 root root 4096 Jul 1 21:13 postfix-2.9.6
-rw-r--r-- 1 root root 3561 Jul 1 21:13 postfix_2.9.6-2_amd64.changes
-rw-r--r-- 1 root root 1529980 Jul 1 21:13 postfix_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 254432 Jul 1 21:12 postfix_2.9.6-2.diff.gz
-rw-r--r-- 1 root root 1492 Jul 1 21:12 postfix_2.9.6-2.dsc
-rw-r--r-- 1 root root 3767309 Mar 11 15:03 postfix_2.9.6.orig.tar.gz
-rw-r--r-- 1 root root 255470 Jul 1 21:13 postfix-cdb_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 367774 Jul 1 21:13 postfix-dev_2.9.6-2_all.deb
-rw-r--r-- 1 root root 1294258 Jul 1 21:13 postfix-doc_2.9.6-2_all.deb
-rw-r--r-- 1 root root 264196 Jul 1 21:13 postfix-ldap_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 257322 Jul 1 21:13 postfix-mysql_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 257376 Jul 1 21:13 postfix-pcre_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 257476 Jul 1 21:13 postfix-pgsql_2.9.6-2_amd64.deb
-rw-r--r-- 1 root root 55009 May 7 08:47 postfix-vda-v11-2.9.6.patch
drwxr-xr-x 7 root root 4096 May 7 01:24 virtualbox-guest-4.1.18
root@server1:/usr/src#postfixおよびpostfix-mysqlパッケージを選択し、次のようにインストールします:
dpkg -i postfix_2.9.6-2_amd64.deb postfix-mysql_2.9.6-2_amd64.deb4 Postfix/Courier用のMySQLデータベースを作成
次に、mailという名前のデータベースを作成します:
mysqladmin -u root -p create mail次に、MySQLシェルに移動します:
mysql -u root -pMySQLシェルで、mailデータベースに対してSELECT、INSERT、UPDATE、DELETE権限を持つユーザーmail_adminを作成します(自分のパスワードに置き換えてください)。このユーザーはPostfixとCourierがメールデータベースに接続するために使用されます:
GRANT SELECT, INSERT, UPDATE, DELETE ON mail.* TO 'mail_admin'@'localhost' IDENTIFIED BY 'mail_admin_password';
GRANT SELECT, INSERT, UPDATE, DELETE ON mail.* TO 'mail_admin'@'localhost.localdomain' IDENTIFIED BY 'mail_admin_password';
FLUSH PRIVILEGES;MySQLシェルのままで、PostfixとCourierに必要なテーブルを作成します:
USE mail;CREATE TABLE domains (
domain varchar(50) NOT NULL,
PRIMARY KEY (domain) )
ENGINE=MyISAM;CREATE TABLE forwardings (
source varchar(80) NOT NULL,
destination TEXT NOT NULL,
PRIMARY KEY (source) )
ENGINE=MyISAM;CREATE TABLE users (
email varchar(80) NOT NULL,
password varchar(20) NOT NULL,
quota INT(10) DEFAULT '10485760',
PRIMARY KEY (email)
) ENGINE=MyISAM;CREATE TABLE transport (
domain varchar(128) NOT NULL default '',
transport varchar(128) NOT NULL default '',
UNIQUE KEY domain (domain)
) ENGINE=MyISAM;quit;ご覧のとおり、quit;コマンドでMySQLシェルを終了し、Linuxシェルに戻りました。
domainsテーブルは、Postfixがメールを受信する各仮想ドメインを保存します(例:example.com)。
| domain |
| example.com |
forwardingsテーブルは、1つのメールアドレスを別のメールアドレスにエイリアスするためのもので、たとえば、[email protected]から[email protected]へのメールを転送します。
| source | destination |
| [email protected] | [email protected] |
usersテーブルは、すべての仮想ユーザー(すなわち、メールアドレス、メールアドレスとユーザー名が同じであるため)とパスワード(暗号化された形式!)および各メールボックスのクォータ値を保存します(この例ではデフォルト値は10485760バイト、つまり10MBです)。
| password | quota | |
| [email protected] | No9.E4skNvGa.(暗号化された形式の「秘密」) | 10485760 |
transportテーブルはオプションで、上級ユーザー向けです。特定のユーザー、全ドメイン、またはすべてのメールを別のサーバーに転送することを可能にします。たとえば、
| domain | transport |
| example.com | smtp:[1.2.3.4] |
は、example.comのすべてのメールをsmtpプロトコルを介してIPアドレス1.2.3.4のサーバーに転送します(角括弧[]は「MX DNSレコードのルックアップを行わない」という意味です(IPアドレスに対しては意味があります…)。完全修飾ドメイン名(FQDN)を使用する場合は、角括弧を使用しません)。
ちなみに、(あなたのメールサーバーシステムのIPアドレスが192.168.0.100であると仮定しています)ブラウザでhttp://192.168.0.100/phpmyadmin/にアクセスし、mail_adminとしてログインできます。次に、データベースを確認できます。後でphpMyAdminを使用してメールサーバーを管理できます。
新しい投稿を受信箱で受け取る
スパムはありません。いつでも購読を解除できます。