Ubuntu 16.04にPostfixをインストールおよび構成する方法

前書き

Postfixは人気のあるオープンソースのMail Transfer Agent(MTA)であり、Linuxシステムで電子メールをルーティングおよび配信するために使用できます。 インターネット上のパブリックメールサーバーの約25%がPostfixを実行していると推定されます。

このガイドでは、Ubuntu 16.04サーバーでPostfixをすばやく起動して実行する方法を説明します。

前提条件

このガイドに従うには、sudo権限を持つroot以外のユーザーにアクセスできる必要があります。 Ubuntu 16.04 initial server setup guideをたどって、必要なユーザーを作成できます。

Postfixを適切に構成するには、Ubuntu 16.04サーバーを指す完全修飾ドメイン名が必要です。 this guideをフォローすると、DigitalOceanでドメイン名を設定するためのヘルプを見つけることができます。 メールの受け入れを計画している場合は、メールサーバーを指すMXレコードも持っていることを確認する必要があります。

このチュートリアルでは、FQDNがmail.example.comのホストを構成していることを前提としています。

ステップ1:Postfixをインストールする

PostfixはUbuntuのデフォルトリポジトリに含まれているため、インストールは非常に簡単です。

まず、ローカルのaptパッケージキャッシュを更新してから、ソフトウェアをインストールします。 いくつかの追加のプロンプトに答えるために、DEBIAN_PRIORITY=low環境変数をインストールコマンドに渡します。

sudo apt-get update
sudo DEBIAN_PRIORITY=low apt-get install postfix

次の情報を使用して、環境に合わせてプロンプトを正しく入力してください。

  • General type of mail configuration?:これはインフラストラクチャのニーズに一致するため、このためにInternet Siteを選択します。

  • System mail name:これは、アドレスのアカウント部分のみが指定されている場合に、有効な電子メールアドレスを作成するために使用されるベースドメインです。 たとえば、サーバーのホスト名はmail.example.comですが、システムメール名をexample.comに設定して、ユーザー名user1を指定すると、Postfixがアドレス[email protected]を使用するようにします。 )s。

  • Root and postmaster mail recipient:これは、root@およびpostmaster@宛てのメールを転送するLinuxアカウントです。 これにはプライマリアカウントを使用します。 この場合、sammyです。

  • Other destinations to accept mail for:これは、このPostfixインスタンスが受け入れるメールの宛先を定義します。 このサーバーが受信する他のドメインを追加する必要がある場合は、ここに追加してください。そうでない場合は、デフォルトで問題なく動作します。

  • Force synchronous updates on mail queue?:ジャーナリングファイルシステムを使用している可能性が高いため、ここでNoを受け入れます。

  • Local networks:これは、メールサーバーがメッセージを中継するように構成されているネットワークのリストです。 デフォルトはほとんどのシナリオで機能するはずです。 変更する場合は、ネットワーク範囲に関して非常に制限が厳しいことを確認してください。

  • Mailbox size limit:これを使用してメッセージのサイズを制限できます。 「0」に設定すると、サイズ制限が無効になります。

  • Local address extension character:これは、アドレスの通常の部分を拡張子(動的エイリアスの作成に使用)から分離するために使用できる文字です。

  • Internet protocols to use:PostfixがサポートするIPバージョンを制限するかどうかを選択します。 目的に合わせて「すべて」を選択します。

明確にするために、これらはこのガイドで使用する設定です。

  • General type of mail configuration?:インターネットサイト

  • System mail name:example.com(mail.example.comではない)

  • Root and postmaster mail recipient:サミー

  • Other destinations to accept mail for:$ myhostname、example.com、mail.example.com、localhost.example.com、localhost

  • Force synchronous updates on mail queue?:いいえ

  • Local networks:127.0.0.0/8 [:: ffff:127.0.0.0] / 104 [:: 1] / 128

  • Mailbox size limit:0

  • Local address extension character

  • Internet protocols to use:すべて

これらの設定を再調整するために戻る必要がある場合は、次のように入力してください。

sudo dpkg-reconfigure postfix

プロンプトには、以前の応答が事前に入力されます。

完了したら、もう少し設定を行って、システムを希望どおりにセットアップできます。

ステップ2:Postfix設定を微調整する

次に、パッケージで要求されなかった設定を調整できます。

最初に、メールボックスを設定できます。 Maildir形式を使用します。これは、メッセージを個々のファイルに分割し、ユーザーの操作に基づいてディレクトリ間を移動します。 もう1つのオプションは、すべてのメッセージを1つのファイルに保存するmbox形式(ここでは説明しません)です。

home_mailbox変数をMaildir/に設定します。これにより、ユーザーのホームディレクトリ内にその名前でディレクトリ構造が作成されます。 postconfコマンドを使用して、構成設定を照会または設定できます。 次のように入力して、home_mailboxを構成します。

sudo postconf -e 'home_mailbox= Maildir/'

次に、virtual_alias_mapsテーブルの場所を設定できます。 この表は、任意の電子メールアカウントをLinuxシステムアカウントにマップします。 このテーブルを/etc/postfix/virtualに作成します。 ここでも、postconfコマンドを使用できます。

sudo postconf -e 'virtual_alias_maps= hash:/etc/postfix/virtual'

ステップ3:メールアドレスをLinuxアカウントにマッピングする

次に、仮想マップファイルを設定できます。 テキストエディターでファイルを開きます。

sudo nano /etc/postfix/virtual

仮想エイリアスマップテーブルは、非常に単純な形式を使用します。 左側には、メールを受け取るアドレスをリストできます。 その後、空白で区切って、メールを配信するLinuxユーザーを入力します。

たとえば、[email protected][email protected]で電子メールを受け入れ、それらの電子メールをsammy Linuxユーザーに配信したい場合は、次のようにファイルを設定できます。

/etc/postfix/virtual

すべてのアドレスを適切なサーバーアカウントにマッピングしたら、ファイルを保存して閉じます。

次のように入力してマッピングを適用できます。

sudo postmap /etc/postfix/virtual

Postfixプロセスを再起動して、すべての変更が適用されたことを確認します。

sudo systemctl restart postfix

ステップ4:ファイアウォールを調整する

UFWファイアウォールを実行している場合は、サーバーの初期セットアップガイドで構成されているように、Postfixの例外を許可する必要があります。

次のように入力して、サービスへの接続を許可できます。

sudo ufw allow Postfix

Postfixサーバーコンポーネントがインストールされ、準備ができました。 次に、Postfixが処理するメールを処理できるクライアントを設定します。

ステップ5:メールの場所に合わせて環境を設定する

クライアントをインストールする前に、MAIL環境変数が正しく設定されていることを確認する必要があります。 クライアントはこの変数を調べて、ユーザーのメールを探す場所を見つけます。

アカウントへのアクセス方法(sshsusu -sudoなど)に関係なく変数を設定するには、変数を設定する必要がありますいくつかの異なる場所で。 これを/etc/bash.bashrc/etc/profile.d内のファイルに追加して、各ユーザーがこれを構成していることを確認します。

これらのファイルに変数を追加するには、次を入力します。

echo 'export MAIL=~/Maildir' | sudo tee -a /etc/bash.bashrc | sudo tee -a /etc/profile.d/mail.sh

変数を現在のセッションに読み込むには、/etc/profile.d/mail.shファイルを入手します。

source /etc/profile.d/mail.sh

手順6:メールクライアントのインストールと構成

配信されるメールを操作するために、s-nailパッケージをインストールします。 これはBSDxmailクライアントのバリアントであり、機能が豊富で、Maildir形式を正しく処理でき、ほとんどの場合下位互換性があります。 mailのGNUバージョンには、ソース形式に関係なく、常に読み取りメールをmbox形式で保存するなど、いくつかの苛立たしい制限があります。

s-nailパッケージをインストールするには、次のように入力します。

sudo apt-get install s-nail

いくつかの設定を調整する必要があります。 エディターで/etc/s-nail.rcファイルを開きます。

sudo nano /etc/s-nail.rc

ファイルの下部に向かって、次のオプションを追加します。

/etc/s-nail.rc

. . .
set emptystart
set folder=Maildir
set record=+sent

これにより、クライアントは空の受信トレイでも開くことができます。 また、Maildirディレクトリを内部folder変数に設定し、これを使用して、送信されたメールを保存するためのsentmboxファイルを作成します。

完了したら、ファイルを保存して閉じます。

ステップ7:Maildirの初期化とクライアントのテスト

これで、クライアントをテストできます。

ディレクトリ構造の初期化

ホームディレクトリ内にMaildir構造を作成する最も簡単な方法は、自分自身に電子メールを送信することです。 これは、mailコマンドで実行できます。 sentファイルは、Maildirが作成された後でのみ使用できるため、最初の電子メールの書き込みを無効にする必要があります。 これを行うには、-Snorecordオプションを渡します。

mailコマンドに文字列をパイプして電子メールを送信します。 コマンドを調整して、Linuxユーザーを受信者としてマークします。

echo 'init' | mail -s 'init' -Snorecord sammy

次の応答が返されます。

OutputCan't canonicalize "/home/sammy/Maildir"

これは正常であり、この最初のメッセージでのみ表示されます。 ~/Maildirディレクトリを探すことで、ディレクトリが作成されたことを確認できます。

ls -R ~/Maildir

ディレクトリ構造が作成され、新しいメッセージファイルが~/Maildir/newディレクトリにあることがわかります。

Output/home/sammy/Maildir/:
cur  new  tmp

/home/sammy/Maildir/cur:

/home/sammy/Maildir/new:
1463177269.Vfd01I40e4dM691221.mail.example.com

/home/sammy/Maildir/tmp:

メールが配信されたようです。

クライアントでメールを管理する

クライアントを使用してメールを確認します。

mail

新しいメッセージが待っているのが見えるはずです。

Outputs-nail version v14.8.6.  Type ? for help.
"/home/sammy/Maildir": 1 message 1 new
>N  1 [email protected]     Wed Dec 31 19:00   14/369   init

ENTERを押すだけで、メッセージが表示されます。

Output[-- Message  1 -- 14 lines, 369 bytes --]:
From [email protected] Wed Dec 31 19:00:00 1969
Date: Fri, 13 May 2016 18:07:49 -0400
To: [email protected]
Subject: init
Message-Id: <[email protected]>
From: [email protected]

init

hと入力すると、メッセージリストに戻ることができます。

h
Outputs-nail version v14.8.6.  Type ? for help.
"/home/sammy/Maildir": 1 message 1 new
>R  1 [email protected]     Wed Dec 31 19:00   14/369   init

このメッセージはあまり役に立たないので、dで削除できます。

d

qと入力して、ターミナルに戻るのをやめます。

q

クライアントでメールを送信する

テキストエディタにメッセージを入力して、メールの送信をテストできます。

nano ~/test_message

内部に、メールで送信するテキストを入力します。

~/test_message

Hello,

This is a test.  Please confirm receipt!

catコマンドを使用して、メッセージをmailプロセスにパイプできます。 これにより、デフォルトでLinuxユーザーとしてメッセージが送信されます。 その値を別の値に変更する場合は、-rフラグを使用して「From」フィールドを調整できます。

cat ~/test_message | mail -s 'Test email subject line' -r from_field_account [email protected]

上記のオプションは次のとおりです。

  • -s:メールの件名

  • -r:電子メールの「From:」フィールドへのオプションの変更。 デフォルトでは、ログインしているLinuxユーザーがこのフィールドの入力に使用されます。 -rオプションを使用すると、これをオーバーライドできます。

  • [email protected]:メールの送信先のアカウント。 これを、アクセスできる有効なアカウントに変更します。

送信したメッセージは、mailクライアント内で表示できます。 次のように入力して、対話型クライアントを再起動します。

mail

その後、次のように入力して送信メッセージを表示します。

file +sent

受信メールに使用するのと同じコマンドを使用して、送信メールを管理できます。

結論

Ubuntu 16.04サーバーでPostfixが設定されているはずです。 電子メールサーバーの管理は、初心者の管理者にとっては難しい作業ですが、この構成では、基本的なMTA電子メール機能が必要です。

Related