2019 年度 OSS リテラシー 3 : メール

メール

メールサーバの設定

MTA (Mail Transfer Agent) として postfix, sendmail, qmail が有名であるが, 今回は外部からのメール受信を行わないので高機能な MTA は必要ない. Debian のデフォルトの MTA である exim を用いることにする. mailutils パッケージをインストールすると, exim 関連のパッケージも一緒にインストールされる.

$ sudo -s

# apt-get update

# apt-get install mailutils

外部へメールを送るための設定を行う. メールの送信には高専のメールサーバ (red.matsue-ct.jp) をリレーする. 外部からのメールは受信しないことにする.

# dpkg-reconfigure exim4-config

dpkg-reconfigure コマンドを実行すると, ターミナル上にグラフィカルな設定画面が表示される. タブを押すと <了解> <取消> を選択することができる.

  • メール設定のタイプ: スマートホストでメール送信; SMTP または fetchmail で受診する
    • メールは全て高専のメールサーバ (スマートホスト) に送信するので. ラズパイから高専の外部のサーバへ SMTP できない.

  • システムメール名: ホスト名 (= 学生番号)
    • デフォルトのホスト名のまま変更しなくて良い. 後ほど書き換えを有効にする.

  • 入力側 SMTP 接続をリスンする IP アドレス: 127.0.0.1
    • 外部からのメールを受信しない. 127.0.0.1 はローカルホストを意味する IP.

  • メールを受け取るその他の宛先: (空欄)
    • 外部からのメールを受信しないので, 設定する必要がない.

  • メールをリレーするマシン: (空欄)
    • ほかのホスト向けのスマートホストにする必要がない

  • スマートホスト: red.matsue-ct.jp

  • 送信するメールでローカルメール名を隠しますか? : はい

  • 表示するローカルユーザのドメイン名: epi.it.matsue-ct.jp
    • epi.it.matsue-ct.jp は情報工学科杉山研究室のサブドメイン.
    • これを有効にしないと, スマートホスト (red.matsue-ct.jp) が受信を拒否する.

  • DNS クエリの数を最小限にとどめますか? : いいえ
    • インターネットに常時接続しているので.

  • ローカルメールの配送方法: /var/mail 内の mbox 形式

  • 設定を小さなファイルに分割しますか? : いいえ

  • root と postmaster のメール受信者: sugiyama
    • 教員のアカウントにしておいて下さい.

ローカルメール配送の確認

ローカルメール配送の確認を行う. まずは mail コマンドを使ってメールを送る.

$ echo "本文" | mail -s "タイトル" hogehoge

mail コマンドで届いたメールを読む.

$ mail

  "/var/mail/hogehoge": 1 message 1 new
  >N   1 HOGEHOGE           土 10月 21 12:  15/466   title
  ? 1                                      (1 を入力) 

  Return-path: <hogehoge@iot-00>
  Envelope-to: hogehoge@iot-00
  Delivery-date: Sat, 21 Oct 2017 12:24:26 +0900
  Received: from hogehoge by iot-00 with local (Exim 4.89)
  (envelope-from <hogehoge@iot-00>)
  id 1e5kOg-0000op-1k
  for hogehoge@iot-00; Sat, 21 Oct 2017 12:24:26 +0900
  Subject: title
  To: <hogehoge@iot-00>
  X-Mailer: mail (GNU Mailutils 3.1.1)
  Message-Id: <E1e5kOg-0000op-1k@iot-00>
  From: HOGEHOGE <hogehoge@iot-00>
  Date: Sat, 21 Oct 2017 12:24:26 +0900

  本文

  ? q                                       (終わるときは q を入力)
  Saved 1 message in /home/hogehoge/mbox
  Held 0 messages in /var/mail/hogehoge

メールの配送ログを確認する. tail コマンドでログファイルの末尾のみを表示する (cat コマンドや less コマンドを利用すればログを全て表示することができる). 以下の例では, hogehoge@iot-00 (iot00 はローカルホスト) にメールを送り, 完了 (completed) していることがわかる.

$ sudo tail /var/log/exim4/mainlog 

  ...(中略)...
  2017-10-21 12:24:26 1e5kOg-0000op-1k <= hogehoge@iot-00 U=hogehoge P=local S=359
  2017-10-21 12:24:26 1e5kOg-0000op-1k => hogehoge <hogehoge@iot-00> R=local_user T=mail_spool
  2017-10-21 12:24:26 1e5kOg-0000op-1k Completed

自分宛てのメールの転送設定

自分宛てのメールを転送する場合は, ホームディレクトリに .forward ファイルを置く.

# exit

$ vi ~/.forward 

  [email protected]       (自分自身のメールアドレスを 1 行だけ書く. 学外のメールアドレスを使う方が良い) 

$ chmod 600 ~/.forward

メールの転送の確認

先に行なった mail コマンドを再度実行する. 学校の PC や携帯でメールが届いたか確認すること.

$ echo "本文" | mail -s "タイトル" hogehoge

ログを確認する. 送信がうまくいけば, OK, completed などの文字が確認できる.

$ sudo tail /var/log/exim4/mainlog 

  ...(中略)...
  2017-10-21 12:52:55 1e5kqF-0001IH-2i <= hogehoge@iot-00 U=hogehoge P=local S=371
  2017-10-21 12:52:55 1e5kqF-0001IH-2i => [email protected] R=smarthost T=remote_smtp_smarthost H=red.matsue-ct.jp [10.0.10.3] C="250 2.0.0 Ok: queued as 7CB4B294108C"
  2017-10-21 12:52:55 1e5kqF-0001IH-2i Completed

もしもメールの配送ログを見て, 以下のようにエラーが生じている場合には, 設定が間違っている. その場合は送信エラーとなっているメールのキューを削除せよ. さらに先に行った dpkg-reconfigure コマンドを実行して再度設定を確認せよ.

$ sudo tail /var/log/exim4/mainlog 

  2017-10-21 12:36:17 1e5ka9-0000qv-Hn <= hogehoge@iot-00 U=hogehoge P=local S=371
  2017-10-21 12:36:17 1e5ka9-0000qv-Hn == [email protected] R=smarthost T=remote_smtp_smarthost defer (-44) H=red.matsue-ct.jp [10.0.10.3]: SMTP error from remote mail server after RCPT TO:<[email protected]>: 450 4.1.8 <hogehoge@iot-00>: Sender address rejected: Domain not found

#  exim -bp | exiqgrep -i | xargs exim -Mrm   (キューの削除)

  Message 1e5ka9-0000qv-Hn has been removed

# dpkg-reconfigure exim4-config (設定しなおし)

  ...(略)...

root などのシステム宛てメールの転送設定

システムが発送する root 宛てのメールの宛先を自分自身に変更しておく. 意味としては, ":" の前に書かれているユーザ宛てのメールを ":" の後ろに書かれているユーザに送る, である. メールアドレスは学外のメールアドレスを用いると良い (学生の場合は, 学内アドレスへの転送がうまくできないため).

# vi /etc/aliases

  mailer-daemon: postmaster
  postmaster: root
  nobody: root
  hostmaster: root
  usenet: root
  news: root
  webmaster: root
  www: root
  ftp: root
  abuse: root
  noc: root
  security: root
  root: [email protected]       (この行を書き換える. 自分自身のメールアドレスに) 

設定を有効にするには, newaliases コマンドを実行する必要がある.

# newaliases

ローカルメールの送受信確認

ローカルメール配送の確認を行う. まずは mail コマンドを使って /etc/aliases の内容が反映されているか確認する.

$ echo "本文1" | mail -s "タイトル1" root

$ echo "本文2" | mail -s "タイトル2" webmaster

$ echo "本文3" | mail -s "タイトル3" postmaster

課題

  • メールのヘッダについて理解を深めるために以下を実行せよ.
    • 上記演習で自分に届いたメール (含むヘッダ) を wbt のオンラインテキストにコピペせよ.
    • メールヘッダ上のキーワード (Return-Path, Deliverd-To, Recieved, Mime-Version, Content-Type, Content-Transfer-Encording, From, To, Subject, Date, Message-Id, など) の意味を調べよ.
    • メールヘッダの情報から読み取れることを文章でまとめよ.