質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.35%

/etc/hostsの記述について

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 9,185

score 307

/etc/hosts
192.168.0.5 a.com

は可能な設定かと思いますが、

/etc/hosts
b.com  a.com


のような設定は不可能ですか?(やってみたらうまくいきませんでした。)

a.com b.comは管理配下です。

他特定ドメインにアクセスしようとすると別のドメインに飛ばす方法は何がありますか?(httpリダイレクト以外)

やりたいのは

program -> ELB -> HAPROXY -> RDS Slave{1,2}

の構成から

program -> Route53(dnsラウンドロビン) -> RDS Slave{1,2}

のように変えたいですが、
プログラムを修正せずにELBへ行くアクセスをRoute53のドメインに飛ばしたいです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • tanat

    2015/12/22 17:17

    a.com及びb.comは管理下にあるドメインでしょうか?

    キャンセル

  • Kimsehwa

    2015/12/22 17:22

    a.com b.comは管理配下です!

    キャンセル

  • tanat

    2015/12/22 17:23

    現在の構成でELBへのアクセスをしている様ですが、ELBへのアクセスはELBのエンドポイント名でのアクセスでしょうか?それともa.comでのアクセスでしょうか?

    キャンセル

回答 3

+1

/etc/hostsは名前解決をするための機構なのでエイリアス的な記述は出来ません。

通常、複数のドメインに対して同じ名前解決をさせたい場合はCNAMEレコードを使用します。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/22 18:09

    今回のケースだと
    (おそらく)ELBのエンドポイントに対してa.comという名前でアクセスしていると思われるので(AliasもしくはCNAME)、

    まず b.comについてDNSラウンドロビンでRDSにアクセスするようにし、
    a.comの既存のレコード全てを削除し、CNAMEでb.comを参照するように指定することで、

    アプリケーションからは
    a.comで名前解決しようとすると、b.comを参照し、b.comの名前解決の結果を取得することになります。
    CNAMEがある場合は他のレコードが存在していてはいけないので、a.comのDNSを完全に自由に出来ない限りは使えません。

    キャンセル

checkベストアンサー

0

hostsでクライアントの設定によりアクセスを変える事は可能です。
サービス目的というよりは、自身の動作検証目的になりますが。

sudo vi /etc/hosts
---
192.168.1.108 a.com b.com
---
$ ping a.com
PING a.com (192.168.1.108) 56(84) bytes of data.
64 bytes from a.com (192.168.1.108): icmp_seq=1 ttl=64 time=0.126 ms
^C
$ ping b.com
PING a.com (192.168.1.108) 56(84) bytes of data.
64 bytes from a.com (192.168.1.108): icmp_seq=1 ttl=64 time=0.124 ms

DNSラウンドロビンの場合

a.com. IN A 192.168.0.5
b.com. IN A 192.168.0.5


のように書けば、名前解決の都度、a.comと b.comの送出順が前後ひっくり返って応答されます。
これをDNSラウンドロビンと呼んでいると思います。

ただ、DNSラウンドロビンでは、サーバのダウンを検知して、負荷をそちらへ振らないようにするには、一工夫しないといけなく、また、クライアント側にDNSキャッシュが残るため、シビアなフェールセーフな構成を期待できなくなってしまいます。
サーバのダウンを検知して負荷を片寄せする、または、メンテナンスの為、片寄せする運用をされるのであれば、ELB(ロードバランサ)機能はあると、いざというとき本当に良かったと思うことになると思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/12/22 18:52

    Route53のDNSフェールオーバーと組み合わせればHAPROXYサーバ置かなくて済むのではないかと思い検討中です。ご意見ありがとうございます!

    キャンセル

  • 2015/12/23 00:06

    一工夫の方は大丈夫そうですね:-)
    後は、DNSでの負荷分散や冗長は、クライアント側のキャッシュに依存する事だけ注意すれば=シビアな(秒単位の切り替えなど)サービスでなければ十分かもしれません。

    キャンセル

  • 2015/12/23 00:40

    横からすみません&認識がずれてたらごめんなさい。

    今回の場合、アプリケーションから呼ぶ名前はa.comのままにしたいということで、
    ****
    sudo vi /etc/hosts
    ---
    192.168.1.108 a.com b.com
    ---
    a.com. IN A 192.168.0.5
    b.com. IN A 192.168.0.5
    *****

    となっている状態でも
    アプリケーションからはa.comを名前解決することになるため、
    常に192.168.0.5が取得されてしまい、ロードバランシングはされないように思います。
    *認識が違っていたらご指摘下さい。

    また、DNSラウンドロビンとは一般的には
    同じ名前について名前解決をした場合に順番にIPが送出される状態を指す物だと思います、DNSレコードとしては
    hoge IN A 127.0.1.1
    hoge IN A 127.0.1.2
    hoge IN A 127.0.1.3
    という様な状態かと思います。

    仮に最終的に接続するDBが192.168.0.6と192.168.0.7の場合は
    [b.comの設定]
    b.com. IN A 192.168.0.6
    b.com. IN A 192.168.0.7
    [a.comの設定]
    a.com. IN CNAME b.com

    とすることで、アプリケーションからa.comを名前解決すると192.168.0.6と192.168.0.7が順番に送出されます。

    ただ、今回のケースでは最終的なエンドポイントがRDSなので(slaveとありますが、おそらくリードレプリカでしょうか・・・)直接IPを指定する事は出来ないため、この方法は使えませんね・・・

    キャンセル

  • 2015/12/24 21:06

    ご指摘ありがとうございます!失礼いたしました。
    Kimsehwa様の期待する動作は、tanat様のおっしゃる方法となります。

    RDSですが、Publicly Accessibleをyes (+セキュリティグループの設定)にてグローバルIPアドレスからのアクセスも可能かとは思いますが、そのような運用はした事がありません・・・

    今後ここを参照される方の事を考えて、ベストアンサーをtanatさまに付け替えて頂けると幸いです。

    キャンセル

0

はい、/etc/hostsは、「IP アドレスとホスト名を関連づけている」ファイルです(man)。ホスト名の読み替え目的には使えません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る