作者 | Pradeep Kumar
譯者 | lujun9972
一年又一年,我們一直在使用 ifconfig 命令來執行網路相關的任務,比如檢查和配置網絡卡資訊。但是 ifconfig 已經不再被維護,並且在最近版本的 Linux 中被廢除了! ifconfig 命令已經被 ip 命令所替代了。
ip 命令跟 ifconfig 命令有些類似,但要強力的多,它有許多新功能。ip 命令完成很多 ifconfig 命令無法完成的任務。
本教程將會討論 ip 命令的 12 中最常用法,讓我們開始吧。
案例 1:檢查網絡卡資訊
檢查網絡卡的諸如 IP 地址,子網等網路資訊,使用 ip addr show 命令:
[linuxtechi@localhost]$ ip addr show
或
[linuxtechi@localhost]$ ip a s
這會顯示系統中所有可用網絡卡的相關網路資訊,不過如果你想檢視某塊網絡卡的資訊,則命令為:
[linuxtechi@localhost]$ ip addr show enp0s3
這裡 enp0s3 是網絡卡的名字。

IP-addr-show-commant-output
案例 2:啟用/禁用網絡卡
使用 ip 命令來啟用一個被禁用的網絡卡:
[linuxtechi@localhost]$ sudo ip link set enp0s3 up
而要禁用網絡卡則使用 down 觸發器:
[linuxtechi@localhost]$ sudo ip link set enp0s3 down
案例 3:為網絡卡分配 IP 地址以及其他網路資訊
要為網絡卡分配 IP 地址,我們使用下麵命令:
[linuxtechi@localhost]$ sudo ip addr add 192.168.0.50/255.255.255.0 dev enp0s3
也可以使用 ip 命令來設定廣播地址。預設是沒有設定廣播地址的,設定廣播地址的命令為:
[linuxtechi@localhost]$ sudo ip addr add broadcast 192.168.0.255 dev enp0s3
我們也可以使用下麵命令來根據 IP 地址設定標準的廣播地址:
[linuxtechi@localhost]$ sudo ip addr add 192.168.0.10/24 brd + dev enp0s3
如上面例子所示,我們可以使用 brd 代替 broadcast 來設定廣播地址。
案例 4:刪除網絡卡中配置的 IP 地址
若想從網絡卡中刪掉某個 IP,使用如下 ip 命令:
[linuxtechi@localhost]$ sudo ip addr del 192.168.0.10/24 dev enp0s3
案例 5:為網絡卡新增別名(假設網絡卡名為 enp0s3)
新增別名,即為網絡卡新增不止一個 IP,執行下麵命令:
[linuxtechi@localhost]$ sudo ip addr add 192.168.0.20/24 dev enp0s3 label enp0s3:1

ip-command-add-alias-linux
案例 6:檢查路由/預設閘道器的資訊
檢視路由資訊會給我們顯示資料包到達目的地的路由路徑。要檢視網路路由資訊,執行下麵命令:
[linuxtechi@localhost]$ ip route show

ip-route-command-output
在上面輸出結果中,我們能夠看到所有網絡卡上資料包的路由資訊。我們也可以獲取特定 IP 的路由資訊,方法是:
[linuxtechi@localhost]$ sudo ip route get 192.168.0.1
案例 7:新增靜態路由
我們也可以使用 IP 來修改資料包的預設路由。方法是使用 ip route 命令:
[linuxtechi@localhost]$ sudo ip route add default via 192.168.0.150/24
這樣所有的網路資料包透過 192.168.0.150 來轉發,而不是以前的預設路由了。若要修改某個網絡卡的預設路由,執行:
[linuxtechi@localhost]$ sudo ip route add 172.16.32.32 via 192.168.0.150/24 dev enp0s3
案例 8:刪除預設路由
要刪除之前設定的預設路由,開啟終端然後執行:
[linuxtechi@localhost]$ sudo ip route del 192.168.0.150/24
註意: 用上面方法修改的預設路由只是臨時有效的,在系統重啟後所有的改動都會丟失。要永久修改路由,需要修改或建立 route-enp0s3 檔案。將下麵這行加入其中:
[linuxtechi@localhost]$ sudo vi /etc/sysconfig/network-scripts/route-enp0s3
172.16.32.32 via 192.168.0.150/24 dev enp0s3
儲存並退出該檔案。
若你使用的是基於 Ubuntu 或 debian 的作業系統,則該要修改的檔案為 /etc/network/interfaces,然後新增 ip route add 172.16.32.32 via 192.168.0.150/24 dev enp0s3 這行到檔案末尾。
案例 9:檢查所有的 ARP 記錄
ARP,是地址解析協議的縮寫,用於將 IP 地址轉換為物理地址(也就是 MAC 地址)。所有的 IP 和其對應的 MAC 明細都儲存在一張表中,這張表叫做 ARP 快取。
要檢視 ARP 快取中的記錄,即連線到區域網中裝置的 MAC 地址,則使用如下 ip 命令:
[linuxtechi@localhost]$ ip neigh

ip-neigh-command-linux
案例 10:修改 ARP 記錄
刪除 ARP 記錄的命令為:
[linuxtechi@localhost]$ sudo ip neigh del 192.168.0.106 dev enp0s3
若想往 ARP 快取中新增新記錄,則命令為:
[linuxtechi@localhost]$ sudo ip neigh add 192.168.0.150 lladdr 33:1g:75:37:r3:84 dev enp0s3 nud perm
這裡 nud 的意思是 “neghbour state”(網路鄰居狀態),它的值可以是:
perm - 永久有效並且只能被管理員刪除noarp - 記錄有效,但在生命週期過期後就允許被刪除了stale - 記錄有效,但可能已經過期reachable - 記錄有效,但超時後就失效了案例 11:檢視網路統計資訊
透過 ip 命令還能檢視網路的統計資訊,比如所有網絡卡上傳輸的位元組數和報文數,錯誤或丟棄的報文數等。使用 ip -s link 命令來檢視:
[linuxtechi@localhost]$ ip -s link

ip-s-command-linux
案例 12:獲取幫助
若你想檢視某個上面例子中沒有的選項,那麼你可以檢視幫助。事實上對任何命令你都可以尋求幫助。要列出 ip 命令的所有可選項,執行:
[linuxtechi@localhost]$ ip help
記住,ip 命令是一個對 Linux 系統管理來說特別重要的命令,學習並掌握它能夠讓配置網路變得容易。本教程就此結束了,若有任何建議歡迎在下麵留言框中留言。
via: https://www.linuxtechi.com/ip-command-examples-for-linux-users/
作者:Pradeep Kumar[2] 譯者:lujun9972 校對:wxy
本文由 LCTT 原創編譯,Linux中國 榮譽推出
知識星球

