序章

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

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

前提条件

このガイドに従うには、sudo権限を持つroot以外のユーザーにアクセスできる必要があります。 Ubuntu 16.04初期サーバーセットアップガイドに従って、必要なユーザーを作成できます。

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

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

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

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

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

  1. sudo apt-get update
  2. sudo DEBIAN_PRIORITY=low apt-get install postfix

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

  • メール構成の一般的なタイプ?:これはインフラストラクチャのニーズに一致するため、インターネットサイトを選択します。
  • システムメール名:これは、アドレスのアカウント部分のみが指定されている場合に有効な電子メールアドレスを作成するために使用されるベースドメインです。 たとえば、サーバーのホスト名はmail.example.comですが、システムメール名をexample.comに設定して、ユーザー名user1を指定すると、Postfixがアドレスを使用するようにします。 [email protected]
  • ルートおよびポストマスターのメール受信者:これは、root@およびpostmaster@宛てのメールを転送するLinuxアカウントです。 これにはプライマリアカウントを使用してください。 この場合、sammyです。
  • メールを受け入れるその他の宛先:これは、このPostfixインスタンスが受け入れるメールの宛先を定義します。 このサーバーが受信を担当する他のドメインを追加する必要がある場合は、ここに追加します。追加しない場合は、デフォルトで正常に機能します。
  • メールキューで同期更新を強制しますか?:ジャーナルファイルシステムを使用している可能性があるため、ここでいいえを受け入れます。
  • ローカルネットワーク:これは、メールサーバーがメッセージを中継するように構成されているネットワークのリストです。 デフォルトはほとんどのシナリオで機能するはずです。 変更する場合は、ネットワーク範囲を非常に制限するようにしてください。
  • メールボックスサイズ制限:これを使用してメッセージのサイズを制限できます。 「0」に設定すると、サイズ制限が無効になります。
  • ローカルアドレス拡張文字:これは、アドレスの通常の部分を拡張から分離するために使用できる文字です(動的エイリアスの作成に使用されます)。
  • 使用するインターネットプロトコル:PostfixがサポートするIPバージョンを制限するかどうかを選択します。 目的のために「すべて」を選択します。

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

  • メール構成の一般的なタイプ?:インターネットサイト
  • システムメール名 example.com mail.example.com ではありません)
  • ルートおよびポストマスターのメール受信者:サミー
  • のメールを受け入れるその他の宛先:$ myhostname、 example.com mail.example.com localhost.example.com 、ローカルホスト
  • メールキューで同期更新を強制しますか?:いいえ
  • ローカルネットワーク:127.0.0.0/8 [:: ffff:127.0.0.0] / 104 [:: 1] / 128
  • メールボックスサイズ制限:0
  • ローカルアドレス拡張文字:+
  • 使用するインターネットプロトコル:すべて

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

  1. sudo dpkg-reconfigure postfix

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

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

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

次に、パッケージが要求しなかったいくつかの設定を調整できます。

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

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

  1. sudo postconf -e 'home_mailbox= Maildir/'

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

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

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

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

  1. sudo nano /etc/postfix/virtual

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

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

/ etc / postfix / virtual
contact@example.com sammy
admin@example.com sammy

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

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

  1. sudo postmap /etc/postfix/virtual

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

  1. sudo systemctl restart postfix

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

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

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

  1. sudo ufw allow Postfix

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

ステップ5:メールの場所と一致するように環境を設定する

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

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

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

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

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

  1. source /etc/profile.d/mail.sh

手順6:メールクライアントをインストールして構成する

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

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

  1. sudo apt-get install s-nail

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

  1. 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ユーザーを受信者としてマークするようにコマンドを調整します。

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

次の応答が返されます。

Output
Can't canonicalize "/home/sammy/Maildir"

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

  1. 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:

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

クライアントによるメールの管理

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

  1. mail

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

Output
s-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 と入力すると、メッセージリストに戻ることができます。

  1. h
Output
s-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で削除できます。

  1. d

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

  1. q

クライアントとのメール送信

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

  1. nano ~/test_message

中に、メールで送信したいテキストを入力します。

〜/ test_message
Hello,

This is a test.  Please confirm receipt!

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

  1. cat ~/test_message | mail -s 'Test email subject line' -r from_field_account user@email.com

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

  • -s:メールの件名
  • -r:電子メールの「From:」フィールドへのオプションの変更。 デフォルトでは、ログインしているLinuxユーザーがこのフィールドに入力するために使用されます。 -rオプションを使用すると、これをオーバーライドできます。
  • [email protected]:メールの送信先のアカウント。 これを、アクセスできる有効なアカウントに変更してください。

mailクライアント内で送信済みメッセージを表示できます。 次のように入力して、インタラクティブクライアントを再起動します。

  1. mail

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

  1. file +sent

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

結論

これで、Ubuntu16.04サーバーでPostfixが設定されているはずです。 電子メールサーバーの管理は、初心者の管理者にとって難しい作業になる可能性がありますが、この構成では、基本的なMTA電子メール機能を使用して開始する必要があります。