请选择 进入手机版 | 继续访问电脑版

[LINUX] Centos(linux)体系 ip下令 使用 方法

[复制链接]
查看53 | 回复18 | 2021-9-5 01:41:25 | 显示全部楼层 |阅读模式

[root@Linux ~]# ip [option] [动作] [下令 ]

参数:

option :设定的参数,紧张 有:
     -s :表现 出该装备 的统计数据(statistics),比方 总担当 封包数等;
  动作:就是是可以针对哪些网络参数举行 动作,包括有:
       link :关于装备 (device) 的干系 设定,包括 MTU, MAC 地址等等
       addr/address :关于额外的 IP 设定,比方 多 IP 的实现等等;
       route :与路由有关的干系 设定

上面的语法我们可以知道, ip 除了可以设定一些基本的网络参数之外,还可以或许 举行 额外的 IP 设定, 包括多 IP 的实现,真是太完满 了!下面我们就分三个部分 (link, addr, route) 来先容 这个 ip 下令 。

关于装备 (device) 的干系 设定: ip link

ip link 可以设定与装备 (device) 有关的干系 设定,包括 MTU 以及该网络装备 的 MAC 等等, 当然也可以启动 (up) 或关闭 (down) 某个网络装备 。整个语法是如许 的:

[root@linux ~]# ip [-s] link show <== 单纯的查阅该装备 干系 的信息
[root@linux ~]# ip link set [device] [动作与参数]

参数:

show:仅表现 出这个装备 的干系 内容,假如 加上 -s 会表现 更多统计数据;
set :可以开始设定项目, device 指的是 eth0, eth1 等等装备 代号;
动作与参数:包括以下动作:
   up|down :启动 (up) 或关闭 (down) 某个装备 ,其他参数利用 预设的以太网参数;
   address :假如 这个装备 可以更改 MAC ,用这个参数修改;
   name     :给予这个装备 一个特殊 的名字;
   mtu      :设置最大传输单元。

范例一:表现 出全部 的装备 信息

[root@linux ~]# ip link show

1: lo: mtu 16436 qdisc noqueue

    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

2: eth0: mtu 1500 qdisc pfifo_fast qlen 1000

    link/ether 00:50:fc:22:9a:cb brd ff:ff:ff:ff:ff:ff

3: sit0: mtu 1480 qdisc noop

    link/sit 0.0.0.0 brd 0.0.0.0

[root@linux ~]# ip -s link show eth0

2: eth0: mtu 1500 qdisc pfifo_fast qlen 1000

    link/ether 00:50:fc:22:9a:cb brd ff:ff:ff:ff:ff:ff

    RX: bytes packets errors dropped overrun mcast

    484011792 2247372 0       0       0       0

    TX: bytes packets errors dropped carrier collsns

    2914104290 2867753 0       0       0       0

利用 ip link show 可以表现 出整个装备 的硬件干系 信息,如上所示,包括 MAC地址、MTU等等, 比较风趣 的应该是谁人 sit0 的装备 了,谁人 sit0 的装备 是将IPv4 和 IPv6 的封包举行 转换, 对于我们仅利用 IPv4 的网络是没有作用的。 lo 及 sit0 都是主机内部自行设定的。 而假如 加上 -s 的参数后,则这个网卡的干系 统计信息就会被列出来, 包括吸收 (RX) 及传送 (TX) 的封包数量 等等,详细 的内容与 ifconfig 所输出的结果 雷同 。

范例二:启动、关闭与设定装备 的干系 信息

[root@linux ~]# ip link set eth0 up
# 启动eth0这个装备 ;
[root@linux ~]# ip link set eth0 down
# 关闭eth0这个装备 ;
[root@linux ~]# ip link set eth0 mtu 1000
# 更改 MTU为1000 bytes,单位就是 bytes 。

更新网卡的 MTU 利用 ifconfig 也可以实。假如 是要更改『网卡代号、 MAC 地址的信息』的话,那可就得利用 ip了,设定前必要 先关闭该网卡,否则会不成功。 如下所示:

范例三:修改网卡代号、MAC 等参数

[root@linux ~]# ip link set eth0 name vbird

SIOCSIFNAME: Device or resource busy

# 由于 该装备 如今 是启动的,以是 不能如许 做设定。你应该要如许 做:

[root@linux ~]# ip link set eth0 down       <==关闭装备
[root@linux ~]# ip link set eth0 name vbird <==重新设定
[root@linux ~]# ip link show                <==查看信息

2. vbird: mtu 900 qdisc pfifo_fast qlen 1000

    link/ehter 00:40:d0:13:c3:46 brd ff:ff:ff:ff:ff:ff

# 呵呵,连网卡代号都可以改变!不过,玩玩后记得改回来啊!

# 由于 我们的 ifcfg-eth0 还是利用 本来 的装备 代号!避免有标题 ,要改回来

[root@linux ~]# ip link set vbird name eth0 <==装备 改回来
[root@linux ~]# ip link set eth0 address aa:aa:aa:aa:aa:aa
[root@linux ~]# ip link show eth0

# 假如 你的网卡支持MAC更改的话,
# 那么上面这个下令 就可以更改你的网卡MAC了!
# 不过,还是那句老话,测试完之后请立即 改回来!

在这个装备 的硬件干系 信息设定,上面包括 MTU, MAC 以及传输的模式等等,都可以在这里设定。 风趣 的是谁人 address 的项目,谁人 项目后面接的但是 MAC地址而不是IP地址很容易 搞错啊!牢记 牢记 !更多的硬件参数可以利用 man ip 查阅一下与 ip link 有关的设定。

关于额外的 IP 干系 设定: ip address

假如 说 ip link 是与 OSI 七层模子 的第二层数据链路层有关的话,那么 ip address (ip addr) 就是与第三层网络层有关的了。紧张 是在设定与 IP 有关的各项参数,包括 netmask, broadcast 等等。

[root@linux ~]# ip address show   <==查看IP参数
[root@linux ~]# ip address [add|del] [IP参数] [dev ?备名] [干系 参数]

参数:

show  :单纯的表现 出装备 的 IP 信息;

add|del :举行 干系 参数的增长 (add) 或删除 (del) 设定,紧张 有:

IP 参数 :紧张 就是网域的设定,比方 192.168.100.100/24 之类的设定;

dev :这个 IP 参数所要设定的装备 ,比方 eth0, eth1 等等;

 干系 参数:如下所示:

        broadcast:设定广播位址,假如 设定值是 + 表示让体系 主动 计算;

        label    :该装备 的别名,比方 eth0:0;

        scope    :这个装备 的范畴 ,通常是以下几个大类:

                   global :答应 来自全部 泉源 的连线;

                   site   :仅支持IPv6 ,仅答应 本主机的毗连 ;

                   link   :仅答应 本装备 自我毗连 ;

                   host   :仅答应 本主机内部的毗连 ;

                   以是 当然是利用 global 了。预设也是 global !

范例一:表现 出全部 装备 的 IP 参数:

[root@linux ~]# ip address show

1: lo: mtu 16436 qdisc noqueue

    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

    inet6 ::1/128 scope host

       valid_lft forever preferred_lft forever

2: eth0: mtu 1500 qdisc pfifo_fast qlen 1000

    link/ether 00:50:fc:22:9a:cb brd ff:ff:ff:ff:ff:ff

    inet 192.168.1.2/24 brd 192.168.1.255 scope global eth0

    inet6 fe80::250:fcff:fe22:9acb/64 scope link

       valid_lft forever preferred_lft forever

3: sit0: mtu 1480 qdisc noop

    link/sit 0.0.0.0 brd 0.0.0.0

下面我们进一步来新增假造 的网络装备 :

范例二:新增一个装备 ,名称假设为 eth0:vbird

[root@linux ~]# ip address add 192.168.50.50/24 broadcast + /

> dev eth0 label eth0:vbird

[root@linux ~]# ip address show eth0

2: eth0: mtu 1500 qdisc pfifo_fast qlen 1000

    link/ether 00:40:d0:13:c3:46 brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.100/24 brd 192.168.1.255 scope global eth0
    inet 192.168.50.50/24 brd 192.168.50.255 scope global eth0:vbird
    inet6 fe80::240:d0ff:fe13:c346/64 scope link

       valid_lft forever preferred_lft forever

# 看上面的输出多出了一行,增长 了新的装备 ,名称是 eth0:vbird

# 至于谁人 broadcast + 也可以写成 broadcast 192.168.50.255 。

[root@linux ~]# ifconfig

eth0:vbir Link encap:Ethernet HWaddr 00:40:D0:13:C3:46
          inet addr:192.168.50.50 Bcast:192.168.50.255 Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
          Interrupt:5 Base address:0x3e00

# 假如 利用 ifconfig 就可以或许 看到这个怪东西了!

范例三:将刚刚的装备 删除

[root@linux ~]# ip address del 192.168.50.50/24 dev eth0

# 删除比较简单。

--------------------------------------------------------------------------------

关于路由的设定: ip route

这个项目就是路由的查看与设定。毕竟 上ip route 的功能几乎与 route 这个下令 一样,但是,它还可以举行 额外的参数设置,比方 MTU 的规划等等,相当 的刁悍 啊!

[root@linux ~]# ip route show <==单纯的表现 出路由的设定
[root@linux ~]# ip route [add|del] [IP或网域] [via gateway] [dev 装备 ]

参数:

show :单纯的表现 出路由表,也可以利用 list ;

add|del :增长 (add) 或删除 (del) 路由;

    IP或网域:可利用 192.168.50.0/24 之类的网域或者是单纯的 IP ;
    via     :从谁人 gateway 出去,不肯定 必要 ;
    dev     :由谁人 装备 连出去,必要 ;
    mtu     :可以额外的设定 MTU 的数值;

范例一:表现 出如今 的路由资料

[root@linux ~]# ip route show
192.168.1.0/24 dev eth0 proto kernel scope link src 192.168.1.2
169.254.0.0/16 dev eth1 scope link
default via 192.168.1.254 dev eth1

如上表所示,最简单的功能就是表现 出如今 的路由信息,实在 跟 route 这个下令 雷同 。必须留意 的几点:

proto:此路由的路由协定,紧张 有 redirect, kernel, boot, static, ra 等, 此中 kernel 指的是直接由核心判断 主动 设定。

scope:路由的范围,紧张 是 link ,是与本装备 有关的直接毗连 。

再来看一下怎样 举行 路由的增长 与删除:

范例二:增长 路由,紧张 是本机直接可沟通的网域

[root@linux ~]# ip route add 192.168.5.0/24 dev eth0

# 针对本机直接沟通的网域设定好路由,不必要 透过外部的路由器

[root@linux ~]# ip route show
192.168.5.0/24 dev eth0 scope link

....以下省略....

范例三:增长 可以通往外部的路由,需透过 router ;

[root@linux ~]# ip route add 192.168.10.0/24 via 192.168.5.100 dev eth0
[root@linux ~]# ip route show

192.168.5.0/24 dev eth0 scope link

....其他省略....

192.168.10.0/24 via 192.168.5.100 dev eth0

# 过细 ,由于 我有 192.168.5.0/24 的路由存在 (与我的网卡直接干系 ),

# 以是 才可以将 192.168.10.0/24 的路由丢给 192.168.5.100

# 那部主机来帮忙传递!与之条件 到的 route 下令 是一样的限定 !

范例四:增长 预设路由

[root@linux ~]# ip route add default via 192.168.1.2 dev eth0

# 谁人 192.168.1.2 就是我的预设路由器(gateway);

# 记住,只要一个预设路由就OK了;

范例五:删除路由

[root@linux ~]# ip route del 192.168.10.0/24
[root@linux ~]# ip route del 192.168.5.0/24 
 
毕竟 上,这个 ip 的下令 着实 是太博大博识 了!刚打仗 Linux 网络的朋侪 ,大概 会看到有点晕!您先会利用 ifconfig, ifup , ifdown 与 route 即可, 等以后有履历 了之后,再继续回来玩 ip 这个好玩的下令 吧!有爱好 的话,也可以自行参考 ethtool 这个下令 !


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

avatar 海上灵光Y8 | 2021-9-5 23:08:48 | 显示全部楼层
楼上的刚出院吧?
回复

使用道具 举报

avatar 东阿制造 | 2021-9-12 13:56:48 | 显示全部楼层
十分赞同admin楼主!
回复

使用道具 举报

avatar 宋751 | 2021-9-12 23:13:46 | 显示全部楼层
看了这么多帖子,第一次看到这么经典的!
回复

使用道具 举报

avatar 我能陪你变老 | 2021-9-16 21:35:57 | 显示全部楼层
admin楼主,我告诉你一个你不知道的的秘密,有一个牛逼的源码论坛他的站点都是商业源码,还是免费下载的那种!特别好用。访问地址:http://www.mxswl.com 猫先森网络
回复

使用道具 举报

avatar ssffgsa | 2021-10-10 16:44:34 | 显示全部楼层
无图无真相!
回复

使用道具 举报

avatar 也曾相识825 | 2021-10-11 04:46:10 | 显示全部楼层
admin楼主今年多大了?
回复

使用道具 举报

avatar 下一个秋天1 | 2021-10-11 20:46:44 | 显示全部楼层
顶顶更健康!
回复

使用道具 举报

avatar 123457166 | 2021-10-13 19:04:07 | 显示全部楼层
admin楼主,替我问候您主治大夫!
回复

使用道具 举报

avatar 普通人物怨 | 2021-10-14 09:35:28 | 显示全部楼层
很经典,收藏了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则