IP、子網掩碼、預設閘道器/預設閘道器、DNS、伺服器、埠的總結

BW開發者發表於2016-10-20

網路的基本概念

  • 客戶端:應用 C/S(客戶端/伺服器) B/S(瀏覽器/伺服器)
  • 伺服器:為客戶端提供服務、資料、資源的機器
  • 請求:客戶端向伺服器索取資料
  • 響應:伺服器對客戶端請求作出反應,一般是返回給客戶端資料

URL

  • Uniform Resource Locator(統一資源定位符)
  • 網路中每一個資源都對應唯一的地址——URL

IP 、子網掩碼 、路由器 、DNS

IP地址

IP地址是IP協議提供的一種統一的地址格式,它為網際網路上的每一個網路和每一臺主機分配一個邏輯地址,以此來遮蔽實體地址(每個機器都有一個編碼,如MAC上就有一個叫MAC地址的東西)的差異。是32位二進位制資料,通常以十進位制表示,並以“.”分隔。IP地址是一種邏輯地地址,用來標識網路中一個個主機,在本地區域網上是惟一的。

IP

IP(網路之間互連的協議)它是能使連線到網上的所有計算機網路實現相互通訊的一套規則,規定了計算機在因特網上進行通訊時應當遵守的規則。任何廠家生產的計算機系統,只要遵守IP協議就可以與因特網互連互通。IP地址有唯一性,即每臺機器的IP地址在全世界是唯一的。這裡指的是網路上的真實IP它是通過本機IP地址和子網掩碼的"與"運算然後再通過各種處理算出來的(要遵守TCP協議還要加報文及埠什麼的,我沒有細追究,現在還用不上,反正暫時知道被處理過的就行了),順便教大家查自己真實IP的方法:

子網掩碼

要想理解什麼是子網掩碼,就不能不瞭解IP地址的構成。網際網路是由許多小型網路構成的,每個網路上都有許多主機,這樣便構成了一個有層次的結構。IP地址在設計時就考慮到地址分配的層次特點,將每個IP地址都分割成網路號和主機號兩部分,以便於IP地址的定址操作。更多精彩內容關注微信公眾號:全棧開發者中心(admin10000_com)
 

IP地址的網路號和主機號各是多少位呢?如果不指定,就不知道哪些位是網路號、哪些是主機號,這就需要通過子網掩碼來實現。什麼是子網掩碼子網掩碼不能單獨存在,它必須結合IP地址一起使用。子網掩碼只有一個作用,就是將某個IP地址劃分成網路地址和主機地址兩部分子網掩碼的設定必須遵循一定的規則。與IP地址相同,子網掩碼的長度也是32位,左邊是網路位,用二進位制數字“1”表示;右邊是主機位,用二進位制數字“0”表示。假設IP地址為“192.168.1.1”子網掩碼為“255.255.255.0”。其中,“1”有24個,代表與此相對應的IP地址左邊24位是網路號;“0”有8個,代表與此相對應的IP地址右邊8位是主機號。這樣,子網掩碼就確定了一個IP地址的32位二進位制數字中哪些是網路號、哪些是主機號。這對於採用TCP/IP協議的網路來說非常重要,只有通過子網掩碼,才能表明一臺主機所在的子網與其他子網的關係,使網路正常工作。

常用的子網掩碼有數百種,這裡只介紹最常用的兩種子網掩碼。

  • 子網掩碼是“255.255.255.0”的網路:
    最後面一個數字可以在0~255範圍內任意變化,因此可以提供256個IP地址。但是實際可用的IP地址數量是256-2,即254個,因為主機號不能全是“0”或全是“1”。

  • 子網掩碼是“255.255.0.0”的網路:
    後面兩個數字可以在0~255範圍內任意變化,可以提供255²個IP地址。但是實際可用的IP地址數量是255²-2,即65023個。

IP地址的子網掩碼設定不是任意的。如果將子網掩碼設定過大,也就是說子網範圍擴大,那麼,根據子網尋徑規則,很可能發往和本地主機不在同一子網內的目標主機的資料,會因為錯誤的判斷而認為目標主機是在同一子網內,那麼,資料包將在本子網內迴圈,直到超時並拋棄,使資料不能正確到達目標主機,導致網路傳輸錯誤;如果將子網掩碼設定得過小,那麼就會將本來屬於同一子網內的機器之間的通訊當做是跨子網傳輸,資料包都交給預設閘道器處理,這樣勢必增加預設閘道器(文章下方有解釋)的負擔,造成網路效率下降。因此,子網掩碼應該根據網路的規模進行設定。如果一個網路的規模不超過254臺電腦,採用“255.255.255.0”作為子網掩碼就可以了,現在大多數區域網都不會超過這個數字,因此“255.255.255.0”是最常用的IP地址子網掩碼;假如在一所大學具有1500多臺電腦,這種規模的區域網可以使用“255.255.0.0”。

閘道器

閘道器實質上是一個網路通向其他網路的IP地址。比如有網路A和網路B,網路A的IP地址範圍為“192.168.1.1~192. 168.1.254”,子網掩碼為255.255.255.0;網路B的IP地址範圍為“192.168.2.1~192. 168.2.254”,子網掩碼為255.255.255.0。在沒有路由器的情況下,兩個網路之間是不能進行TCP/IP通訊的,即使是兩個網路連線在同一臺交換機(或集線器)上,TCP/IP協議也會根據子網掩碼(255.255.255.0)判定兩個網路中的主機處在不同的網路裡。而要實現這兩個網路之間的通訊,則必須通過閘道器。如果網路A中的主機發現資料包的目標主機不在本地網路中,就把資料包轉發給它自己的閘道器,再由閘道器轉發給網路B的閘道器,網路B的閘道器再轉發給網路B的某個主機。網路B向網路A轉發資料包的過程也是如此 所以說,只有設定好閘道器的IP地址,TCP/IP協議才能實現不同網路之間的相互通訊。那麼這個IP地址是哪臺機器的IP地址呢?閘道器的IP地址是具有路由功能的裝置的IP地址,具有路由功能的裝置有路由器、啟用了路由協議的伺服器(實質上相當於一臺路由器)、代理伺服器(也相當於一臺路由器)。

路由器(Windows下叫預設閘道器,閘道器就是路由,路由就是閘道器不要蒙)

如果搞清了什麼是閘道器,預設閘道器也就好理解了。就好像一個房間可以有多扇門一樣,一臺主機可以有多個閘道器。預設閘道器的意思是一臺主機如果找不到可用的閘道器,就把資料包發給預設指定的閘道器,由這個閘道器來處理資料包。現在主機使用的閘道器,一般指的是預設閘道器。
下方是百度百科給出的解釋

如何設定預設閘道器 一臺電腦的預設閘道器是不可以隨隨便便指定的,必須正確地指定,否則一臺電腦就會將資料包發給不是閘道器的電腦,從而無法與其他網路的電腦通訊。預設閘道器的設定有手動設定和自動設定兩種方式。

  • 手動設定:手動設定適用於電腦數量比較少、TCP/IP引數基本不變的情況,比如只有幾臺到十幾臺電腦。因為這種方法需要在聯入網路的每臺電腦上設定“預設閘道器”,非常費勁,一旦因為遷移等原因導致必須修改預設閘道器的IP地址,就會給網管帶來很大的麻煩,所以不推薦使用。需要特別注意的是:預設閘道器必須是電腦自己所在的網段中的IP地址,而不能填寫其他網段中的IP地址。

  • 自動設定:自動設定就是利用DHCP伺服器來自動給網路中的電腦分配IP地址、子網掩碼和預設閘道器。這樣做的好處是一旦網路的預設閘道器發生了變化時,只要更改了DHCP伺服器中預設閘道器的設定,那麼網路中所有的電腦均獲得了新的預設閘道器的IP地址。這種方法適用於網路規模較大、TCP/IP引數有可能變動的網路。另外一種自動獲得閘道器的辦法是通過安裝代理伺服器軟體(如MS Proxy)的客戶端程式來自動獲得,其原理和方法和DHCP有相似之處。由於篇幅所限,就不再詳述了。

預設閘道器

預設閘道器(Default Gateway)是計算機網路中一個如何將資料包轉發到其他網路中的節點。在一個典型的TCP / IP網路,節點(如伺服器、工作站和網路裝置)都有一個定義的預設路由設定(指向預設閘道器)。可以在沒有特定路由的情況下,明確出傳送資料包的下一跳IP地址。更多精彩內容關注微信公眾號:全棧開發者中心(admin10000_com)
下方是百度百科給出的解釋:

可以看出預設閘道器就是預設閘道器,那麼有人會說既然有一樣為什麼又憑空多出來一個預設閘道器,我的理解是這樣的,應該說預設閘道器是預設閘道器的一個子集。預設閘道器有一個定義的預設路由設定(指向預設閘道器),預設閘道器就相當於一個代理伺服器暫時管理髮送的資料包,當傳送到目標主機時先由目標主機的預設閘道器接收再找到對應的預設閘道器,就相當於預設閘道器是父類,預設閘道器是子類~~

DNS伺服器

域名伺服器(Domain Name Server)。在Internet上域名與IP地址之間是一一對應的,域名雖然便於人們記憶,但機器之間只能互相認識IP地址,它們之間的轉換工作稱為域名解析,域名解析需要由專門的域名解析伺服器來完成,DNS就是進行域名解析的伺服器 。

DHCP伺服器

DHCP指的是由伺服器控制一段IP地址範圍,客戶機登入伺服器時就可以自動獲得伺服器分配的IP地址和子網掩碼。提升地址的使用率。

MAC地址

MAC地址就如同我們身份證上的身份證號碼,具有全球唯一性。(知道這個就行了,不用往下看了)
MAC(Media Access Control,介質訪問控制)地址

  • 前24位叫做組織唯一標誌符(Organizationally Unique Identifier,即OUI),是由IEEE的註冊管理機構給不同廠家分配的程式碼,區分了不同的廠家。
  • 後24位是由廠家自己分配的,稱為擴充套件識別符號。同一個廠家生產的網路卡中MAC地址後24位是不同的。
    網路卡的實體地址通常是由網路卡生產廠家燒入網路卡的EPROM(一種快閃記憶體晶片,通常可以通過程式擦寫),它儲存的是傳輸資料時真正賴以標識發出資料的電腦和接收資料的主機的地址。

也就是說,在網路底層的物理傳輸過程中,是通過實體地址來識別主機的,它一定是全球唯一的。比如,著名的乙太網卡,其實體地址是48bit(位元位)的整數,如:44-45-53-54-00-00,以機器可讀的方式存入主機介面中。乙太網地址管理機構(除了管這個外還管別的)(IEEE)(IEEE:電氣和電子工程師協會)將乙太網地址,也就是48位元的不同組合,分為若干獨立的連續地址組,生產乙太網網路卡的廠家就購買其中一組,具體生產時,逐個將唯一地址賦予乙太網卡。

在一個穩定的網路中,IP地址和MAC地址是成對出現的。如果一臺計算機要和網路中另一外計算機通訊,那麼要配置這兩臺計算機的IP地址,MAC地址是網路卡出廠時設定的,這樣配置的IP地址就和MAC地址形成了一種對應關係。在資料通訊時,IP地址負責表示計算機的網路層地址,網路層裝置(如路由器)根據IP地址來進行操作;MAC地址負責表示計算機的資料鏈路層地址,資料鏈路層裝置(如交換機)根據MAC地址來進行操作。IP和MAC地址這種對映關係由ARP(Address Resolution Protocol,地址解析協議)協議完成。

伺服器

  1. 伺服器的分類
    按照軟體開發階段來分,伺服器可以大致分為2種
    (1)遠端伺服器
    別名:外網伺服器、正式伺服器
    使用階段:應用上線後使用的伺服器
    使用人群:供全體使用者使用
    速度:伺服器的效能、使用者的網速
    (2)本地伺服器
    別名:內網伺服器、測試伺服器
    使用階段:應用處於開發、測試階段使用的伺服器
    使用人群:僅供公司內部的開發人員、測試人員使用
    速度:由於是區域網,所以速度飛快,有助於提高開發測試效率

  2. 本地伺服器的選擇
    遠端伺服器就是本地內網伺服器開放外網訪問而已
    如果處於學習、開發階段,自己搭建一個本地伺服器即可

埠號

埠包括物理埠和邏輯埠。物理埠是用於連線物理裝置之間的介面,邏輯埠是邏輯上用於區分服務的埠。TCP/IP協議中的埠就是邏輯埠,通過不同的邏輯埠來區分不同的服務。
埠有什麼用呢?我們知道,一臺擁有IP地址的主機可以提供許多服務,比如Web服務、FTP服務、SMTP服務等,這些服務完全可以通過1個IP地址來實現。那麼,主機是怎樣區分不同的網路服務呢?顯然不能只靠IP地址,因為IP 地址與網路服務的關係是一對多的關係。實際上是通過“IP地址+埠號”來區 分不同的服務的。

  • 公認埠(Well-Known Ports)
    這類埠也常稱之為"常用埠"。這類埠的埠號從0到1023,它們緊密繫結於一些特定的服務。通常這些埠的通訊明確表明了某種服務的協議,這種埠是不可再重新定義它的作用物件。80埠實際上總是HTTP通訊所使用的,而23號埠則是Telnet服務專用的。
  • 註冊埠(Registered Ports)
    埠號從1025到49151。分配給使用者程式或應用程式。這些程式主要是使用者選擇安裝的一些應用程式,而不是分配好的公認埠的常用程式。
  • 動態和/或私有埠(Dynamic and/or Private Ports)
    之所以稱為動態埠,因為它一般不固定分配某種服務,而是動態分配。

相關文章