/etc/hosts を正しく設定する方法

/etc/hosts を正しく設定する方法

私はネットワーキングについて学んでいます。家には、アプリケーションをテストするために使用する2つの物理マシンと複数の仮想マシンがあります。各マシンには異なるホスト名があり、それらを各/ etc / hostsファイルマッピングに手動で追加します。

ホームIPアドレス(127.0.0.1)と/ etc / hostsにあるネットワークが提供する実際のIPアドレスの違いが何であるかを知りたいです。

例えば

私のIPアドレスが192.168.2.20で、ホスト名がnarutoであると仮定すると、私の/ etc / hostsは次のようになります。

127.0.0.1       localhost
192.168.2.20    naruto
127.0.0.1       naruto

すべての行は同じシステムを指しています。主な違いは、プログラムがループバックデバイスを使用して2つとネットワークカードを使用して各ラインに接続する方法です。私の質問はこの行をすべて持っている必要がありますか?それとも、どの行を立てるべきですか?それぞれの用途は何ですか?

私はこれを読んでいます郵便はがきしかし、役に立たず、さらに混乱しました。

答え1

質問1

ホームIPアドレス(127.0.0.1)と/ etc / hostsにあるネットワークが提供する実際のIPアドレスの違いが何であるかを知りたいです。

127.0.0.1の2つの主な機能:

  • コンピュータの外部のインターネットではルーティングできません。
  • IPアドレス127.0.0.1は、システムのこのインターフェイスに関連付けられているIPアドレスブロックの一部です。

たとえば、ループバックインターフェイスを見てくださいlo

$ ip a l lo
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever

IP ブロックは次の行で設計されています。

    inet 127.0.0.1/8 scope host lo

この/8表記では、ここに示されている32ビットのうち8ビットはネットワークアドレスであり、残りのビット(32-8 = 24)はそのコンピュータで必要なすべてのアドレスを指定するために使用されます。

私たちはこれが範囲であることを自信を持って確信することができます。ping127.0.0.1、127.0.0.2、127.0.0.3を使用します。

$ ping -c2 127.0.0.1
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.029 ms
64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.055 ms

$ ping -c2 127.0.0.2
PING 127.0.0.2 (127.0.0.2) 56(84) bytes of data.
64 bytes from 127.0.0.2: icmp_seq=1 ttl=64 time=0.029 ms
64 bytes from 127.0.0.2: icmp_seq=2 ttl=64 time=0.052 ms

$ ping -c2 127.0.0.3
PING 127.0.0.3 (127.0.0.3) 56(84) bytes of data.
64 bytes from 127.0.0.3: icmp_seq=1 ttl=64 time=0.030 ms
64 bytes from 127.0.0.3: icmp_seq=2 ttl=64 time=0.075 ms

メモ:私たちは、これらすべてがループバックインターフェイスを介して自分自身に「ping」できることを知っています。

以下を使用してtraceroute同じことを示します。

$ traceroute -n 127.0.0.1
traceroute to 127.0.0.1 (127.0.0.1), 30 hops max, 60 byte packets
 1  127.0.0.1  0.032 ms  0.041 ms  0.010 ms

$ traceroute -n 127.0.0.2
traceroute to 127.0.0.2 (127.0.0.2), 30 hops max, 60 byte packets
 1  127.0.0.2  0.033 ms  0.009 ms  0.008 ms

$ traceroute -n 127.0.0.3
traceroute to 127.0.0.3 (127.0.0.3), 30 hops max, 60 byte packets
 1  127.0.0.3  0.034 ms  0.010 ms  0.008 ms

質問2

私の質問はこの行をすべて持っている必要がありますか?それとも、どの行を持っている必要がありますか?それぞれの用途は何ですか?

私の提案は、システムが自動的に割り当てない限り、127.0.0.1に名前を割り当てないことです。通常、次の種類の項目を表示できます/etc/hosts

127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4

システムホスト名に追加のlocalhostタイプIPを割り当てるには、127.0.0.2を使用し、デフォルト設定の127.0.0.1を残します。

さらに、自分のホストに割り当てられている実際のIPアドレスに次のように割り当てるか、/etc/hostsDNSを使用します。

192.168.2.20    naruto.mydom.com naruto

しかし、私は2つの別々の行に同じ名前を付けません。/etc/hostsファイルは最初の項目にのみ応答し、2番目の項目には到達しないため、この方法は決して機能しません。

ワンタイムタスクの場合、/etc/hostsローカルタスクを使用するのは簡単です。ただし、ネットワークから名前とIPのマッピングにアクセスできるようにするには、DNSを使用し、/etc/hostsローカルIP /名前解決以外の方法を使用しないことをお勧めします。

答え2

ディストリビューションが数年前に始めたことの1つは、localhostに127.0.0.1を使用し、ホスト名として127.0.1.1を使用することです。

だから...

/etc/hostname存在する-

naruto

/etc/hosts存在する-

127.0.0.1 localhost
127.0.1.1 naruto

それはすべてです。 (必要に応じてIPv6コンテンツを追加する)何らかの理由でDNSエントリを取得できない場合、または通常はDNSにあるものをリダイレクトする場合にのみ、ループバックではなくIPを/ etc / hostsに配置します。

関連情報