LoginSignup
1
0

More than 5 years have passed since last update.

CloudGarage メールサーバ構築したのにコケた話。

Last updated at Posted at 2017-10-18

はじめに

これはメールサーバ構築自体の話ではないです。クラウドでサーバ構築した時にコケたポイント。既知の問題のようですが。メモ程度に

前提環境

  • 利用クラウド:CloudGarage
  • sshホスト:Debian9
  • sshクライアント:Bash on Ubuntu on Windows10
  • apache2.4
  • postfix
  • dovecot
  • 取得ドメイン:hoge.com と仮定
  • Gmailに来たメールのドメイン:fuga.novalocalと仮定

何がどうしてこうなった?

  1. CloudGarageさんのクラウドをお借りしたので開発用に利用
  2. 予め用意されていたDebian9のイメージを利用してインストール。apache2.4(今回関係なし) postfix dovecot という極めて標準的な環境を構築しました。
  3. httpサーバ構築が完了後、メールサーバ構築をし、Gmailのアドレスにテストメールを送信。
  4. 自分の取得したドメインでは無いところからメールが届く
    というながれ。

本当の悪はどこにある?

ドメインがおかしい、と言ったときに見るポイントは多いと思うのですが…

* DNSサーバへの登録は正しいのか?
* ローカル内で解決できているのか?(localhostなどへの送信時にどうなるのか)
* はたまた、サーバソフトは正しく設定されていて、正常に作動しているのか?

といったところになるかと思います。


確認でやったこと

  1. ドメインの名前解決はできているか?
    →apache正常起動確認後、Windowsのブラウザから取得ドメインでアクセスできる。
  2. サーバソフトの設定は正しいか?
    →postfix,dovecotともに、syntax errorなく正常稼働
  3. localhost宛にメールを送る
  4. fuga.novalocalからメールが来る←!?
    ここで、「おいおいおい、なんじゃこれは…」と。 /etc/postfix/main.cfには
mydomain = hoge.com
myhostname = hoge.com
myorigin = $mydomain

と書かれている。

(゚д゚)ハッ このfuga.novalocalのfugaは既視感がある。何を隠そう自分でインスタンスを立てた際のホスト名。ならば
5. /etc/hosts をいじるまで。
127.0.0.1 fuga.novalocal fuga
127.0.0.1 hoge.com fuga.novalocal fugaに変更し保存。

メールをGmailに再送し、確認

キタ━━━━(゚∀゚)━━━━!!
メールは登録したドメインでやってきた。

これで終わりだと思ったら大間違いだった

実はここからが本題。実はこの/etc/hostsの変更、インスタンス再起動で失効する。ナンテコッタ/(^o^)\

Twitterに書き込んだところこのような返答が…


実際に/etc/hostsを開いたときに
キャプチャ77.PNG
なぁんてかいてある。

要するに、/etc/hostsは起動時に /etc/cloud/template/hosts.debian.tmplから読み込まれているのである。

よって、変更が必要な際は、/etc/cloud/template/hosts.debian.tmplを書き換えないといけない。

でこれを開いて127.0.0.1 hoge.com fuga.novalocal fugaと追記。

これで再起動でも反映される。やったね!!


追記

CloudGarageさんも対応してくださり、FAQが追加されています。
こちらの方法でも回避できるようですのでご確認ください。

CloudGarage 公式FAQ


ご覧いただきありがとうございました。

Thanks

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0