127.0.0.0與0.0.0.0的區別
1. IP地址分類
ref :https://tools.ietf.org/html/rfc1700 page 3
IP地址表示
IP地址由兩個部分組成,net-id和host-id,即網路號和主機號。
net-id:表示ip地址所在的網路號。
host-id:表示ip地址所在網路中的某個主機號碼。
即:
IP-address ::= { <Network-number>, <Host-number> }
IP地址分類
IP地址一共分為5類,即A~E,它們分類的依據是其net-id所佔的位元組長度以及網路號前幾位。
- A類地址:網路號佔1個位元組。網路號的第一位固定為0。
- B類地址:網路號佔2個位元組。網路號的前兩位固定為10。
- C類地址:網路號佔3個位元組。網路號的前三位固定位110。
- D類地址:前四位是1110,用於多播(multicast),即一對多通訊。
- E類地址:前四位是1111,保留為以後使用。
其中,ABC三類地址為單播地址(unicast),用於一對一通訊,是最常用的。
特殊IP地址
特殊IP地址就是用來做一些特殊的事情。RFC1700中定義了以下特殊IP地址。
- {0,0}:網路號和主機號都全部為0,表示“本網路上的本主機”,只能用作源地址。
- {0,host-id}:本網路上的某臺主機。只能用作源地址。
- {-1,-1}:表示網路號和主機號的所有位上都是1(二進位制),用於本網路上的廣播,只能用作目的地址,發到該地址的資料包不能轉發到源地址所在網路之外。
- {net-id,-1}:直接廣播到指定的網路上。只能用作目的地址。
- {net-id,subnet-id,-1}:直接廣播到指定網路的指定子網路上。只用作目的地址。
- {net-id,-1,-1}:直接廣播到指定網路的所有子網路上。只能用作目的地址。
- {127,}:即網路號為127的任意ip地址。都是內部主機迴環地址(loopback),永遠都不能出現在主機外部的網路中。
區別與聯絡
0.0.0.0
IPV4中,0.0.0.0地址被用於表示一個無效的,未知的或者不可用的目標。
- 在伺服器中,0.0.0.0指的是本機上的所有IPV4地址,如果一個主機有兩個IP地址,192.168.1.1 和 10.1.2.1,並且該主機上的一個服務監聽的地址是0.0.0.0,那麼通過兩個ip地址都能夠訪問該服務。
- 在路由中,0.0.0.0表示的是預設路由,即當路由表中沒有找到完全匹配的路由的時候所對應的路由。
用途總結:
- 當一臺主機還沒有被分配一個IP地址的時候,用於表示主機本身。(DHCP分配IP地址的時候)
- 用作預設路由,表示”任意IPV4主機”。
- 用來表示目標機器不可用。
- 用作服務端,表示本機上的任意IPV4地址。
127.0.0.1
127.0.0.1屬於{127,}集合中的一個,而所有網路號為127的地址都被稱之為迴環地址,所以迴環地址!=127.0.0.1,它們是包含關係,即迴環地址包含127.0.0.1。
迴環地址:所有發往該類地址的資料包都應該被loop back。
用途:
- 迴環測試,通過使用ping 127.0.0.1 測試某臺機器上的網路裝置,作業系統或者TCP/IP實現是否工作正常。
- DDos攻擊防禦:網站收到DDos攻擊之後,將域名A記錄到127.0.0.1,即讓攻擊者自己攻擊自己。
- 大部分Web容器測試的時候繫結的本機地址。
localhost
相比127.0.0.1,localhost具有更多的意義。localhost是個域名,而不是一個ip地址。之所以我們經常把localhost與127.0.0.1認為是同一個是因為我們使用的大多數電腦上都講localhost指向了127.0.0.1這個地址。
在ubuntu系統中,/ets/hosts檔案中都會有如下內容:
127.0.0.1 localhost
127.0.1.1 jason-Lenovo-V3000
# The following lines are desirable for IPv6 capable hosts
::1 ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
localhost是一個域名,用於指代this computer或者this host,可以用它來獲取執行在本機上的網路服務。
在大多數系統中,localhost被指向了IPV4的127.0.0.1和IPV6的::1。
IPV4 127.0.0.1 localhost
IPV6 ::1 localhost
127.0.0.1 是一個環回地址。並不表示“本機”。0.0.0.0才是真正表示“本網路中的本機”。
當服務端繫結埠到0.0.0.0,就可以通過多個地址訪問這個服務,而不受內外網的限制(存在安全隱患)。
ref:
wiki:https://zh.wikipedia.org/wiki/Localhost
https://blog.csdn.net/u012814696/article/details/55098249
https://www.iana.org/assignments
https://tools.ietf.org/html/rfc1700
https://www.rfc-editor.org/