在linux中查看arp地址解析協(xié)議需要使用終端命令。
創(chuàng)新互聯(lián)建站專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、宿遷網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5、成都商城網(wǎng)站開發(fā)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為宿遷等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
以Deepin linux為例,使用終端命令查看arp步驟如下所示:
1、在程序列表中點擊打開終端命令程序。
2、在終端命令中輸入查看arp命令:arp -g 。
3、如圖所示,即是本地arp地址解析協(xié)議。
從ip_finish_output2到dev_queue_xmit路徑:
arp協(xié)議:
(1).硬件類型:
硬件地址類型,該字段值一般為ARPHRD_ETHER,表示以太網(wǎng)。
(2).協(xié)議類型:
表示三層地址使用的協(xié)議,該字段值一般為ETH_P_IP,表示IP協(xié)議
(3)硬件地址長度,以太網(wǎng)MAC地址就是6;
(4)協(xié)議地址長度,IP地址就是4;
(5)操作碼
常見的有四種,arp請求,arp相應(yīng),rarp請求,rarp相應(yīng)。
(6)發(fā)送方硬件地址與IP地址,(7)目標(biāo)硬件地址與目標(biāo)IP地址。
arp頭數(shù)據(jù)結(jié)構(gòu):
arp模塊的初始化函數(shù)為arp_init(),這個函數(shù)在ipv4協(xié)議棧的初始化函數(shù)inet_init()中被調(diào)用。
1.初始化arp表arp_tbl;
2.注冊arp協(xié)議類型;
3.建立arp相關(guān)proc文件,/proc/net/arp;
4.注冊通知事件
一個neigh_table對應(yīng)一種鄰居協(xié)議,IPv4就是arp協(xié)議。用來存儲于鄰居協(xié)議相關(guān)的參數(shù)、功能函數(shù)、鄰居項散列表等。
一個neighbour對應(yīng)一個鄰居項,就是一個arp條目
鄰居項函數(shù)指針表,實現(xiàn)三層和二層的dev_queue_xmit()之間的跳轉(zhuǎn)。
用來存儲統(tǒng)計信息,一個結(jié)構(gòu)實例對應(yīng)一個網(wǎng)絡(luò)設(shè)備上的一種鄰居協(xié)議。
注冊arp報文類型 :dev_add_pack(arp_packet_type);
就是把arp_packet_type添加到ptype_base哈希表中。
注冊新通知事件的時候,在已經(jīng)注冊和UP的設(shè)備上,會調(diào)用一次這個通知事件。
設(shè)備事件類型:
創(chuàng)建一個鄰居項,并將其添加到散列表上,返回指向該鄰居項的指針。
tbl:待創(chuàng)建的鄰居項所屬的鄰居表,即arp_tbl;
pkey:三層協(xié)議地址(IP地址)
dev:輸出設(shè)備
want_ref:??
創(chuàng)建鄰居項
1.設(shè)置鄰居項的類型
2.設(shè)置鄰居項的ops指針
3.設(shè)置鄰居項的output函數(shù)指針
調(diào)用dst_link_failure()函數(shù)向三層報告錯誤,當(dāng)鄰居項緩存中還有未發(fā)送的報文,而該鄰居卻無法訪問時被調(diào)用。不懂。
用來發(fā)送arp請求,在鄰居項狀態(tài)定時器處理函數(shù)中被調(diào)用。
neigh:arp請求的目的鄰居項
skb:緩存在該鄰居項中的待發(fā)送報文,用來獲取該skb的源ip地址。
將得到的硬件源、目的地址,IP源、目的地址等作為參數(shù),調(diào)用arp_send()函數(shù)創(chuàng)建一個arp報文并將其輸出。
創(chuàng)建及發(fā)送arp報文
創(chuàng)建arp報文,填充字段。
發(fā)送arp報文
用來從二層接收并處理一個arp報文。這個函數(shù)中就是做了一些參數(shù)檢查,然后調(diào)用arp_process()函數(shù)。
neigh_event_ns
neigh_update
這個函數(shù)的作用就是更新鄰居項硬件地址和狀態(tài)。分支比較多。
neigh_update_notify
代理arp(proxy arp),通常像路由器這樣的設(shè)備才使用,用來代替處于另一個網(wǎng)段的主機回答本網(wǎng)段主機的arp請求。
感覺代碼ARP好像沒啥用呀。
網(wǎng)絡(luò)主機發(fā)包的一般過程:
1.當(dāng)目的IP和自己在同一網(wǎng)段時,直接arp請求該目的IP的MAC。
2.當(dāng)目的IP和自己不再同一網(wǎng)段時,arp請求默認(rèn)網(wǎng)關(guān)的MAC。
當(dāng)主機沒有默認(rèn)網(wǎng)關(guān)的時候,arp請求別的網(wǎng)段的報文,到達路由器后,本來路由器是要隔離廣播的,把這個arp請求報文給丟棄,這樣就沒法通信了。當(dāng)路由器開啟arp proxy后,路由器發(fā)現(xiàn)請求的目的IP在其他網(wǎng)段,就自己給主機回復(fù)一個arp響應(yīng)報文,這樣源主機就把路由器的MAC當(dāng)成目的IP主機對應(yīng)的MAC,可以通信了。這樣可能會造成主機arp表中,多個IP地址都對應(yīng)于路由器的同一個MAC地址。
可以使用arping命令發(fā)送指定IP的arp請求報文。
寫完了發(fā)現(xiàn)這個老妹寫的arp代理文章蠻好的,不過她好像是轉(zhuǎn)載的。
命令紅色字體標(biāo)記
系統(tǒng)初始arp環(huán)境
[root@esx ~]# arp -n
Address ? ? ? ? ? ? ? ? HWtype ?HWaddress ? ? ? ? ? ? Flags Mask Iface
192.168.1.175 ? ? ? ? ? ether ? 00:24:1D:97:B6:7F ? C ?vswif0
192.168.1.120 ? ? ? ? ? ether ? 00:1F:C6:3A:DC:81 ? ? ?C ?vswif0
192.168.1.51 ? ? ? ? ? ?(incomplete) ? ? ? ? vswif0
執(zhí)行清除所有arp 緩存命令
[root@esx ~]# arp -n|awk '/^[1-9]/{print "arp -d ?" $1}'|sh -x
+ arp -d 192.168.1.175
+ arp -d 192.168.1.120
+ arp -d 192.168.1.51
Linux是一套免費使用和自由傳播的類Unix操作系統(tǒng),是一個基于POSIX和UNIX的多用戶、多任務(wù)、支持多線程和多CPU的操作系統(tǒng)。它能運行主要的UNIX工具軟件、應(yīng)用程序和網(wǎng)絡(luò)協(xié)議。它支持32位和64位硬件。Linux繼承了Unix以網(wǎng)絡(luò)為核心的設(shè)計思想,是一個性能穩(wěn)定的多用戶網(wǎng)絡(luò)操作系統(tǒng)。
組合命令清楚所有arp緩存:
[html] view plaincopy
arp -n|awk '/^[1-9]/{system("arp -d "$1)}'
以上命令必須 root 才可以執(zhí)行。
使用ip命令清除某一網(wǎng)絡(luò)接口的arp(下面命令是 eth0 接口)
[html] view plaincopy
ip neigh flush ?dev eth0
Linux 清除arp緩存是把列表標(biāo)記為(incomplete),在下一次系統(tǒng)清理垃圾是會清除。
.首先給虛擬機設(shè)置2塊網(wǎng)卡:
2、關(guān)閉系統(tǒng)中的NetworkManager:
3、編輯文件/etc/modprobe.d/dist.conf添加alias bond0 bonding:
4、修改/etc/sysconfig/network-scripts中的ifcfg-eth0 ifcfg-eth1并創(chuàng)建bond0:
?
miimon是指多久時間要檢查網(wǎng)路一次,單位是ms(毫秒)
mode=0:平衡負載模式,兩塊網(wǎng)卡都在工作,負載均衡。
mode=1:自動主備模式,其中一塊網(wǎng)卡在工作(若eth0斷掉)
則自動切換到另一個塊網(wǎng)卡(eth1做備份)實驗結(jié)果:
1、重啟網(wǎng)絡(luò).service network restart,或者計算機。
2、用另外一臺虛擬機ping網(wǎng)卡綁定后的主機。
3、任意ipdown任意網(wǎng)卡,網(wǎng)絡(luò)通訊均不受影響。
對于網(wǎng)絡(luò)負載均衡是我們在文件服務(wù)器中常用到的,比如把三塊網(wǎng)卡,當(dāng)做一塊來用,解決一個IP地址,流量過大,服務(wù)器網(wǎng)絡(luò)壓力過大的問題。 對于文件服務(wù)器來說,比如NFS或SAMBA文件服務(wù)器,沒有任何一個管理員會把內(nèi)部網(wǎng)的文件服務(wù)器的IP地址弄很多個來解決網(wǎng)絡(luò)負載的問題。
如果在內(nèi)網(wǎng)中,文件服務(wù)器為了管理和應(yīng)用上的方便,大多是用同一個IP地址。對于一個百M的本地網(wǎng)絡(luò)來說,文件服務(wù)器在多個用戶同時使用的情況下,網(wǎng)絡(luò)壓力是極大的,特別是SAMABA和NFS服務(wù)器。為了解決同一個IP地址,突破流量的限制,畢竟網(wǎng)線和網(wǎng)卡對數(shù)據(jù)的吞吐量是有限制的。如果在有限的資源的情況下,實現(xiàn)網(wǎng)絡(luò)負載均衡. 網(wǎng)卡
操作步驟: 1.首先給虛擬機設(shè)置2塊網(wǎng)卡:
添加網(wǎng)卡
2、關(guān)閉系統(tǒng)中的NetworkManager:
關(guān)閉NetWorkManager服務(wù)
3、編輯文件/etc/modprobe.d/dist.conf添加alias bond0 bonding: 編輯網(wǎng)卡綁定配置文件
4、修改/etc/sysconfig/network-scripts中的ifcfg-eth0 ifcfg-eth1并創(chuàng)建bond0: 創(chuàng)建bond0
miimon是指多久時間要檢查網(wǎng)路一次,單位是ms(毫秒) mode=0:平衡負載模式,兩塊網(wǎng)卡都在工作,負載均衡。 mode=1:自動主備模式,其中一塊網(wǎng)卡在工作(若eth0斷掉)
則自動切換到另一個塊網(wǎng)卡(eth1做備份)實驗結(jié)果:
1、重啟網(wǎng)絡(luò).service network restart,或者計算機。
2、用另外一臺虛擬機ping網(wǎng)卡綁定后的主機。
3、任意ipdown任意網(wǎng)卡,網(wǎng)絡(luò)通訊均不受影響。使用bind綁定多個網(wǎng)卡
由于服務(wù)器上對于可用性的要求都比較高,對于各項功能都會有有冗余設(shè)計,比如,磁盤、電源、網(wǎng)卡、甚至服務(wù)器本身等等,今天嘗試做一下網(wǎng)卡綁定實現(xiàn)網(wǎng)卡的冗余。
網(wǎng)卡綁定的實現(xiàn)表面上看起來有些像是硬盤實現(xiàn)邏輯卷,都是通過創(chuàng)建一個邏輯設(shè)備來實現(xiàn)的。實現(xiàn)網(wǎng)卡的綁定其實還挺簡單的,相比邏輯卷更容易理解。
首先,我們在/etc/sysconfig/network-scripts/目錄下創(chuàng)建一個文件,文件名通常會叫ifcfg-bondxx,除了ifcfg-后面的內(nèi)容其實都是可以自己定義的,但通常都會寫成bind之類的,文件的內(nèi)容其實和普通網(wǎng)卡配置文件的內(nèi)容是一樣的,就像這樣第一行的DEVICE是你給這個邏輯設(shè)備指定的名字,這個名字得和文件名的后半部分一樣。
第二行是指定IP的獲取方式,你也可以寫dhcp讓他自動獲取,如果是自動獲取,那么IPADDR、GATEWAY和PREFIX都不需要再填
最后一行是比較重要的,必須得填,這個是綁定網(wǎng)卡的選項,mode代表綁定網(wǎng)卡的工作模式,miimon是一個時間間隔,代表備份網(wǎng)卡每隔多久查詢一次工作網(wǎng)卡的工作情況。單位是ms
以上只是第一步,邏輯網(wǎng)卡已經(jīng)創(chuàng)建好了,下面就要指定那些網(wǎng)卡屬于這個邏輯網(wǎng)卡了。也很簡單,只要把你想加入這個邏輯網(wǎng)卡的物理網(wǎng)卡的配置文件稍微修改一下就可以了。就像這樣