linux 网络工具(一)

linux 网络工具

    • 1. nmcli命令
      • 1.1 介绍
      • 1.2 networking 网络控制
      • 1.3 connection 连接管理
      • 1.4 device 设备管理
      • 1.5 nmcli 返回状态码
    • 2. ifcfg命令家族
      • 2.1 ifconfig
      • 2.2 route
      • 2.3 netstat
    • 3. 静态路由
      • Centos
      • Ubuntu - netplan
      • Ubuntu - network-manager

在这里插入图片描述

1. nmcli命令

1.1 介绍

RHEL 和 CentOS 系统默认使用 NetworkManager 来提供网络服务,这是一种动态管理网络配置的守护进程,能够让网络设备保持连接状态。可以使用 nmcli 命令来管理 NetworkManager 服务。nmcli 是一款基于命令行的网络配置工具,功能丰富,参数众多。

mcli命令 是一个非常丰富和灵活的命令行工具,可以完成网卡上的所有配置,并可以写入配置文件中
centos默认安装,而ubuntu需要手动安装apt install network-manager

SYNOPSIS

NAME
       nmcli - command-line tool for controlling NetworkManager

SYNOPSIS
       nmcli [OPTIONS...] {help | general | networking | radio | connection | device | agent | monitor} [COMMAND] [ARGUMENTS...]

OPTIONS

选项作用
-t简洁输出,会将多余的空格删除,
-p人性化输出,输出很漂亮
-n优化输出,有两个选项tabular(不推荐)和multiline(默认)
-c颜色开关,控制颜色输出(默认启用)
-f过滤字段,all为过滤所有字段,common打印出可过滤的字段
-g过滤字段,适用于脚本,以:分隔
-w超时时间

COMMANDS

  1. general 常规选项
    命令格式:nmcli general {status|hostname|permissions|logging}
    命令描述:使用此命令可以显示网络管理器状态和权限,你可以获取和更改系统主机名,以及网络管理器日志记录级别和域。
  • status
    显示网络管理器的整体状态。
    [root@node1 ~]# nmcli gen status
    STATE      CONNECTIVITY  WIFI-HW  WIFI     WWAN-HW  WWAN
    connected  full          enabled  enabled  enabled  enabled
    
  • hostname
    获取主机名或该更主机名,在没有给定参数的情况下,打印配置的主机名,当指定了参数,它将被移交给NetworkManager,以设置为新的系统主机名。立即生效,并且重启后仍有效。
    [root@node1 ~]# nmcli gen hostname node1-centos
    [root@node1 ~]# cat /etc/hostname
    node1-centos
    
  • permissions
    显示当前用户对网络管理器可允许的操作权限。 如启用和禁用网络、更改WI-FI和WWAN状态、修改连接等。
    [root@node1 ~]# nmcli gen permission
    PERMISSION                                                        VALUE
    org.freedesktop.NetworkManager.enable-disable-network             yes
    org.freedesktop.NetworkManager.enable-disable-wifi                yes
    org.freedesktop.NetworkManager.enable-disable-wwan                yes
    ...
    
  • logging
    获取和更改网络管理器日志记录级别和域,没有任何参数当前日志记录级别和域显示。为了更改日志记录状态, 请提供级别和域参数,有关可用级别和域值, 参阅NetworkManager.conf(5)
    [root@node1 ~]# nmcli gen logging
    LEVEL  DOMAINS                                                                                                                            
    INFO
    PLATFORM,RFKILL,ETHER,WIFI,BT,MB,DHCP4,DHCP6,PPP,IP4,IP6,AUTOIP4,DNS,VPN,SHARING,SUPPLICANT,AGENTS,SETTINGS,SUSPEND,CORE,DEVICE,OLPC,INFINIBAND,FIREWALL,ADSL,BOND,VLAN,BRIDGE,TEAM,CONCHECK,DCB,DISPATCH,AUDIT,SYSTEMD,PROXY
    

1.2 networking 网络控制

命令格式:nmcli networking {on|off|connectivity}
命令描述:查询网络管理器网络状态,开启和关闭网络

选项:

    on: 开启所有接口
    off: 禁用所有接口
    connectivity: 获取网络状态,可选参数check告诉网络管理器重新检查连接性,否则显示最近已知的状态。而无需重新检查。(可能的状态如下所示)
        - none: 主机为连接到任何网络
        - portal: 无法到达完整的互联网
        - limited: 主机已连接到网络,但无法访问互联网
        - full: 主机连接到网络,并具有完全访问
        - unknown: 无法找到连接状态
	[root@node1 ~]# nmcli networking connectivity
	full
	[root@node1 ~]# nmcli networking connectivity check
	full
	[root@node1 ~]# nmcli networking off
	[root@node1 ~]#
	Network error: Software caused connection abort	#好的,连不上了

1.3 connection 连接管理

命令格式:nmcli connection {show|up|down|modify|add|edit|clone|delete|monitor|reload|load|import|export}
这是主要使用的一个功能

  • show

    show有两种用法,分别是:

    ① 列出活动的连接,或进行排序(±为升降序)

    # 查看所有连接状态
    [root@www ~]# nmcli connection show
    # 等同于nmcli connection show --order +active
    [root@www ~]# nmcli connection show --active
    # 以活动的连接进行排序
    [root@www ~]# nmcli connection show --order +active
    # 将所有连接以名称排序
    [root@www ~]# nmcli connection show --order +name
    # 将所有连接以类型排序(倒序)
    [root@www ~]# nmcli connection show --order -type
    

    ② 查看指定连接的详细信息

    [root@node1 ~]# nmcli connection show --order +name
    NAME                UUID                                  TYPE      DEVICE
    System ens33        c96bc909-188e-ec64-3a96-6a90982b08ad  ethernet  --
    Wired connection 1  e741eeb8-242e-3dad-8f70-df385496b90f  ethernet  --
    Wired connection 2  d05a7dea-7039-39c7-9089-d462f1402c4b  ethernet  ens33
    [root@node1 ~]# nmcli connection show ens33
    Error: ens33 - no such connection profile.		#奇怪并不好用
    
  • up/down
    激活连接/停用连接,提供连接名称或uuid进行激活,若未提供,则可以使用ifname指定设备名进行激活。

[root@node1 ~]# nmcli conn up ifname ens33
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/6)
  • modify
    这些属性可以用nmcli connection show eth0进行获取,然后可以修改、添加或删除属性,若要设置属性,只需指定属性名称后跟值,空值将删除属性值,同一属性添加多个值使用+。同一属性删除指定值用-加索引。
    • 添加多个ip
    	# 添加三个
    	[root@www ~]# nmcli connection modify eth0 +ipv4.addresses 192.168.100.102/24
    	[root@www ~]# nmcli connection modify eth0 +ipv4.addresses 192.168.100.103/24
    	[root@www ~]# nmcli connection modify eth0 +ipv4.addresses 192.168.100.104/24
    	# 查看
    	[root@www ~]# nmcli -f IP4 connection show eth0
    	IP4.ADDRESS[1]:                         192.168.100.101/24
    	IP4.GATEWAY:                            192.168.100.100
    	IP4.DNS[1]:                             8.8.8.8
    	# 启用配置
    	[root@www ~]# nmcli connection up eth0
    	Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/18)
    	# 再次查看
    	[root@www ~]# nmcli -f IP4 connection show eth0
    	IP4.ADDRESS[1]:                         192.168.100.101/24
    	IP4.ADDRESS[2]:                         192.168.100.102/24
    	IP4.ADDRESS[3]:                         192.168.100.103/24
    	IP4.ADDRESS[4]:                         192.168.100.104/24
    	IP4.GATEWAY:                            192.168.100.100
    	IP4.DNS[1]:                             8.8.8.8
    
    
    • 删除指定ip
    	[root@www ~]# nmcli -f IP4 connection show eth0
    	IP4.ADDRESS[1]:                         192.168.100.101/24
    	IP4.ADDRESS[2]:                         192.168.100.102/24
    	IP4.ADDRESS[3]:                         192.168.100.103/24
    	IP4.ADDRESS[4]:                         192.168.100.104/24
    	IP4.GATEWAY:                            192.168.100.100
    	IP4.DNS[1]:                             8.8.8.8
    	# 删除索当前索引为2的地址
    	[root@www ~]# nmcli connection modify eth0 -ipv4.addresses 2
    	# 查看
    	[root@www ~]# nmcli -f IP4 connection show eth0
    	IP4.ADDRESS[1]:                         192.168.100.101/24
    	IP4.ADDRESS[2]:                         192.168.100.102/24
    	IP4.ADDRESS[3]:                         192.168.100.103/24
    	IP4.ADDRESS[4]:                         192.168.100.104/24
    	IP4.GATEWAY:                            192.168.100.100
    	IP4.DNS[1]:                             8.8.8.8
    	# 再次激活
    	[root@www ~]# nmcli connection up eth0
    	Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/19)
    	# 查看
    	[root@www ~]# nmcli -f IP4 connection show eth0
    	IP4.ADDRESS[1]:                         192.168.100.101/24
    	IP4.ADDRESS[2]:                         192.168.100.102/24
    	IP4.GATEWAY:                            192.168.100.100
    	IP4.DNS[1]:                             8.8.8.8
    
  • add
    这是创建一个新的连接,需要指定新创建连接的属性,语法与modify相同。
[root@www ~]# nmcli con add con-name eth1 type ethernet  autoconnect yes ifname eth0
# con-name     		连接名称
# type              连接类型
# autoconnect 		是否自动连接
# ifname          	连接到的设备名称

更多的类型或方法可以使用nmcli connection add help查看。

  • clone

克隆连接,克隆一个存在的连接,除了连接名称和uuid是新生成的,其他都是一样的。

[root@www ~]# nmcli connection clone eth0 eth0_1
  • delete

删除连接,这将删除一个连接。

[root@www ~]# nmcli connection delete eth0_1
  • load

从磁盘加载/重新加载一个或多个连接文件,例如你手动创建了一个/etc/sysconfig/network-scripts/ifcfg-ethx连接文件,你可以将其加载到网络管理器,以便管理。

[root@www ~]# echo -e "TYPE=Ethernet\nNAME=ethx" > /etc/sysconfig/network-scripts/ifcfg-ethx
[root@www ~]# nmcli connection show
NAME  UUID                                  TYPE            DEVICE 
eth0  5fb06bd0-0bb0-7ffb-45f1-d6edd65f3e03  802-3-ethernet  eth0 
[root@www ~]# nmcli connection load /etc/sysconfig/network-scripts/ifcfg-ethx 
[root@www ~]# nmcli connection show
NAME  UUID                                  TYPE            DEVICE 
eth0  5fb06bd0-0bb0-7ffb-45f1-d6edd65f3e03  802-3-ethernet  eth0   
ethx  d45d97fb-8530-60e2-2d15-d92c0df8b0fc  802-3-ethernet  --
  • monitor

监视连接配置文件活动。每当指定的连接更改时, 此命令都会打印一行。要监视的连接由其名称、UUID 或 D 总线路径标识。如果 ID 不明确, 则可以使用关键字 id、uuid 或路径。有关 ID 指定关键字的说明, 请参阅上面的连接显示。

监视所有连接配置文件, 以防指定无。当所有监视的连接消失时, 该命令将终止。如果要监视连接创建, 请考虑使用带有 nmcli 监视器命令的全局监视器

[root@www ~]# nmcli connection monitor eth0

1.4 device 设备管理

命令格式:nmcli device {status|show|set|connect|reapply|modify|disconnect|delete|monitor|wifi|lldp}
显示和管理设备接口。该选项有很多功能,例如连接wifi,创建热点,扫描无线,邻近发现等,下面仅列出常用选项。详细功能可使用nmcli device help查看。

  • status

    打印设备状态,如果没有将命令指定给nmcli device,则这是默认操作。

    	[root@www ~]# nmcli device status
    	DEVICE  TYPE      STATE      CONNECTION 
    	eth0    ethernet  connected  eth0       
    	lo      loopback  unmanaged  --         
    	[root@www ~]# nmcli device
    	DEVICE  TYPE      STATE      CONNECTION 
    	eth0    ethernet  connected  eth0       
    	lo      loopback  unmanaged  --
    
  • show

    显示所有设备接口的详细信息。

    # 不指定设备接口名称,则显示所有接口的信息
    [root@www ~]# nmcli device show eth0
    GENERAL.DEVICE:                         eth0
    GENERAL.TYPE:                           ethernet
    GENERAL.HWADDR:                         00:0C:29:99:9A:A1
    GENERAL.MTU:                            1500
    GENERAL.STATE:                          100 (connected)
    GENERAL.CONNECTION:                     eth0
    GENERAL.CON-PATH:                       /org/freedesktop/NetworkManager/ActiveConnection/9
    WIRED-PROPERTIES.CARRIER:               on
    IP4.ADDRESS[1]:                         192.168.100.101/24
    IP4.ADDRESS[2]:                         192.168.100.102/24
    IP4.GATEWAY:                            192.168.100.100
    IP4.DNS[1]:                             8.8.8.8
    
  • set

    设置设备属性

    [root@www ~]# nmcli device set ifname eth0 autoconnect yes
    
  • connect

    连接设备。提供一个设备接口,网络管理器将尝试找到一个合适的连接, 将被激活。它还将考虑未设置为自动连接的连接。(默认超时为90s)

    [root@www ~]# nmcli dev connect eth0
    Device 'eth0' successfully activated with '5fb06bd0-0bb0-7ffb-45f1-d6edd65f3e03'.
    
  • reapply(重新申请)

    使用上次应用后对当前活动连接所做的更改来更新设备。

    [root@www ~]# nmcli device reapply eth0
    Connection successfully reapplied to device 'eth0'.
    
  • modify

    修改设备上处于活动的设备,但该修改只是临时的,并不会写入文件。(语法与 nmcli connection modify 相同)

    [root@www ~]# nmcli device modify eth0 +ipv4.addresses 192.168.100.103/24
    Connection successfully reapplied to device 'eth0'.
    [root@www ~]# nmcli dev show eth0
    [root@www ~]# nmcli device modify eth0 -ipv4.addresses 1
    Connection successfully reapplied to device 'eth0'.
    
  • disconnect

    断开当前连接的设备,防止自动连接。但注意,断开意味着设备停止!但可用 connect 进行连接

    [root@www ~]# nmcli device disconnect eth0
    
  • delete

    删除设备,该命令从系统中删除接口。请注意, 这仅适用于诸如bonds, bridges, teams等软件设备。命令无法删除硬件设备 (如以太网)。超时时间为10秒

    [root@www ~]# nmcli device delete bonds
    
  • monitor

    监视设备活动。每当指定的设备更改状态时, 此命令都会打印一行。

    监视所有设备以防未指定接口。当所有指定的设备消失时, 监视器将终止。如果要监视设备添加, 请考虑使用带有 nmcli 监视器命令的全局监视器。

    [root@www ~]# nmcli device monitor eth0
    

1.5 nmcli 返回状态码

mcli 如果成功退出状态值为0,如果发生错误则返回大于0的值。

状态码说明
0成功-指示操作已成功
1位置或指定的错误
2无效的用户输入,错误的nmcli调用
3超时了(请参阅 --wait 选项)
4连接激活失败
5连接停用失败
6断开设备失败
7连接删除失败
8网络管理器没有运行
10连接、设备或接入点不存在
65当使用 --complete-args 选项,文件名应遵循。

2. ifcfg命令家族

ifcfg命令家族:ifconfig、route和netstat
前文提到ifcfg命令家族功能和ip相似,并且长时间未维护,很有可能被ip取代,所以本文将简要介绍

2.1 ifconfig

语法及参数

  • ifconfig命令的英文全称是“network interfaces configuring”,即用于配置和显示Linux内核中网络接口的网络参数。

  • 用ifconfig命令配置的网卡信息,在网卡重启后机器重启后,配置就不存在。要想将上述的配置信息永远的存的电脑里,那就要修改网卡的配置文件了。

  • 此工具在net-tools工具包中,可以通过yum install net-tools安装

NAME
       ifconfig - configure a network interface

SYNOPSIS
       ifconfig [-v] [-a] [-s] [interface]
       ifconfig [-v] interface [aftype] options | address ...

interface:接口的名称。这通常是一个驱动程序名,后面跟着一个单元号,例如用于第一个以太网接口的eth0。

选项options

选项说明
up此标志将导致激活接口。如果将地址分配给接口,则会隐式指定该地址。
down此标志导致关闭此接口的驱动程序。
[-]arp启用或禁用在此接口上使用ARP协议。
[-]promisc启用或禁用接口的混杂模式。如果选中,网络上的所有数据包都将由接口接收。混杂模式是指一台机器的网卡能够接收所有经过它的数据流,而不论其目的地址是否是它。
[-]allmulti启用或禁用所有多播模式。如果选中,则接口将接收网络上的所有多播数据包。
metric N此参数设置接口度量。它在GNU/Linux下不可用
mtu N此参数设置接口的最大传输单元(MTU)。
dstaddr addr为点对点链路(如PPP)设置远程IP地址.这个关键字现在已经过时了;使用pointopoint关键字代替。
netmask addr设置此接口的IP网络掩码。此值默认为通常的A、B或C类网络掩码(从接口IP地址派生),但可以设置为任何值。
add addr/prefixlen向接口添加IPv 6地址
del addr/prefixlen从接口中删除IPv 6地址
tunnel ::aa.bb.cc.dd创建一个新的SIT(IPv6-in-IPv4)设备,通过隧道到达给定的目的地。
irq addr设置此设备使用的中断行。并非所有设备都可以动态更改其IRQ设置。
io_addr addr为该设备设置I/O空间中的起始地址
mem_start addr设置此设备使用的共享内存的起始地址。只有少数几个设备需要这个
media type设置设备要使用的物理端口或介质类型。并非所有设备都可以更改此设置,以及那些可以更改其支持的值的设备。典型的类型值是10 base 2(细以太网)、10 base T(双绞线10 Mbps以太网)、AUI(外收发信机)等。驱动的特殊介质类型可以用来告诉驱动对媒体进行自动感知。同样,并不是所有的驱动都能做到这一点。
[-]broadcast [addr]如果地址参数给定,则为该接口设置协议广播地址。否则,设置(或清除)接口的IFF_BROADCAST标志。
[-]pointopoint [addr]这个关键字启用了接口的点对点模式,这意味着它是两台机器之间的直接链接,没有其他人监听它。如果地址参数也给出了,就像过时的dstaddr关键字一样,设置链接另一端的协议地址。否则,设置或清除接口的IFF_POINTOPOINT标志。
hw class address如果设备驱动程序支持此操作,则设置此接口的硬件地址(mac地址)。关键字后面必须跟着硬件类的名称和相当于硬件地址的可打印的ASCII。目前支持的硬件类包括ether (以太网)、ax25(AMPRAX.25)、ARCnet和netrom(AMPR NET/ROM)。
multicast在接口上设置多播标志。这通常不应该需要,因为驱动程序本身设置正确的标志。
address要分配给此接口的IP地址。
txqueuelen length设置设备的传输队列的长度。对于具有高延迟(调制解调器链路,ISDN)的较慢设备,将其设置为小值是有用的,以防止快速批量传输过多地干扰诸如telnet之类的交互通信。
  1. 接口及地址查看
    ifconfig [interface]
    ifconfig -a 显示所有接口,-a可缺省
[root@node1 ~]# ifconfig ens33
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.71.183  netmask 255.255.255.0  broadcast 192.168.71.255
        inet6 fe80::3872:4f8b:dbfc:1aa2  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:79:08:6b  txqueuelen 1000  (Ethernet)
        RX packets 14790  bytes 1205753 (1.1 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 1636  bytes 148104 (144.6 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        device interrupt 19  base 0x2000
  1. 启用或者禁用接口
    ifconfig IFACE IP/MASK [up/down]
[root@node1 ~]# ifconfig ens33 192.168.71.184/24 down	#好的,连不上了
[root@node1 ~]# ifconfig ens33 192.168.71.184/24 up

注意:地址及掩码可缺省

也可以以这种形式:
ifconfig ens33 192.168.71.184 netmask 255.255.255.0 down

  1. 临时修改网络地址
    ifconfig IFACE IP netmask NETMASK
[root@node1 ~]# ifconfig ens33 192.168.71.184/24

重启后失效,如果要长久使用,则需要修改配置文件

  1. 显示摘要信息
[root@node1 ~]# ifconfig -s
Iface      MTU    RX-OK RX-ERR RX-DRP RX-OVR    TX-OK TX-ERR TX-DRP TX-OVR Flg
docker0          1500        0      0      0 0             0      0      0      0 BMU
docker_gwbridge  1500     3472      0      0 0           534      0      0      0 BMU
ens33            1500     3472      0      0 0           534      0      0      0 BMRU
lo              65536        0      0      0 0             0      0      0      0 LRU
virbr0           1500        0      0      0 0             0      0      0      0 BMU
  1. 修改网卡MAC地址
[root@node1 ~]# ifconfig docker0 hw ether 00:0c:29:49:e3:f4

2.2 route

route命令:路由查看及管理,路由条目类型:

	1.	主机路由:目标地址为单个ip
	2.	网络路由:目标地址为ip网络
	3.	默认路由:目标为任意主机,0.0.0./0.0.0.0

1. 查看
route -n 显示数字IP,不加n反解地址及端口号

[root@node1 ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         192.168.71.1    0.0.0.0         UG    100    0        0 ens33
192.168.71.0    0.0.0.0         255.255.255.0   U     100    0        0 ens33
[root@node1 ~]# route
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
default         gateway         0.0.0.0         UG    100    0        0 ens33
192.168.71.0    0.0.0.0         255.255.255.0   U     100    0        0 ens33

U表示活跃,G表示网关

2. 添加

route add [-net|-host] target [netmask Nm] [gw GW] [[dev] if]

1 - net 网络路由,host主机路由
2 - target 网络地址
3 - netmask 子网掩码
4 - gw 网关,下一跳地址

添加指定网段的网关

route add -net 192.168.72.0/24(或写为netmask 255.255.255.0) gw 192.168.20.1 dev enp1s0 

解释:

192.168.72.0为指定到达的网络
192.168.20.1为下一跳的网关,必须与自己的某块网卡在同一网络中
dev enp1s0 由哪个网卡访问,可省略

添加路由记录,指定通过eth0网卡传输到192.168.5.0网段的数据

route add -net 192.168.5.0 netmask 255.255.255.0 dev eth0

添加默认网关:

route add default gw 192.168.0.1 #添加默认网关

3. 删除

route del  [-net|-host] target [netmask Nm] [gw GW] [[dev] if]

示例1:

route del -net 192.168.72.0/24 [gw 192.168.20.1]	#网关可缺省

示例2:

route del default

2.3 netstat

Print network connections, routing tables, interface statistics, masquerade connec‐tions, and multicast memberships

  1. 显示路由表信息
netstat -rn

和route -n大体相似

-r 显示内核路由表
-n 不反解ip为主机名

[root@node1 ~]# netstat -rn
Kernel IP routing table
Destination     Gateway         Genmask         Flags   MSS Window  irtt Iface
0.0.0.0         192.168.71.1    0.0.0.0         UG        0 0          0 ens33
172.17.0.0      0.0.0.0         255.255.0.0     U         0 0          0 docker0
  1. 显示网络连接
netstat [-t/--tcp][-u/--udp]	  		  	 		
参数说明
-ttcp协议相关链接,均有其状态:FSM (finite state machine,有限状态机)
-uudp协议相关
-w裸套接字相关连接
-l处于监听状态的连接,不加表示已建立
-a所有状态,不加表示当前只处于连接中的,不包括-l
-n以数字格式显示ip
-e扩展格式
-p显示相关进程和pid

常用组合:-nltp,-nlup, -tan, -uan

[root@node1 ~]# netstat -nltp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN      857/rpcbind
...
tcp6       0      0 ::1:25                  :::*                    LISTEN      1347/master
[root@node1 ~]# netstat -nlup
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
udp        0      0 192.168.122.1:53        0.0.0.0:*                           1636/dnsmasq
...
udp        0      0 0.0.0.0:602             0.0.0.0:*                           857/rpcbind
  1. 显示接口相关的统计数据
netstat -i/-I<无空格>[IFACE] # IFACE为接口名字

① 所有接口:

[root@node1 ~]# netstat -i
Kernel Interface table
Iface             MTU    RX-OK RX-ERR RX-DRP RX-OVR    TX-OK TX-ERR TX-DRP TX-OVR Flg
ens33            1500    40099      1      9 0          6142      0      0      0 BMRU
lo              65536        0      0      0 0             0      0      0      0 LRU
virbr0           1500        0      0      0 0             0      0      0      0 BMU

② 指定接口:

netstat -I<eth1> #不能加空格
[root@node1 ~]# netstat -Iens33
Kernel Interface table
Iface             MTU    RX-OK RX-ERR RX-DRP RX-OVR    TX-OK TX-ERR TX-DRP TX-OVR Flg
ens33            1500    42409      1      9 0          6364      0      0      0 BMRU

3. 静态路由

前面介绍的都是临时添加路由,如何在服务器重启后,添加的路由仍能生效?

Centos

在/etc/sysconfig/network-script/目录下创建名为route- eth0的文件,eth0为网卡名称,一般为eth0、ens33等

在此文件添加如下格式的内容

	192.168.1.0/24 via 192.168.0.1 dev eth0

重启网络验证

	systemctl restart network

Ubuntu - netplan

修改/etc/netplan/*.yaml配置文件

	# This file describes the network interfaces available on your system
	# For more information, see netplan(5).
	network:
	  version: 2
	  renderer: networkd
	  ethernets:
	    eth0:
	      addresses:
	       - 192.168.0.2/24
	        gateway4: 192.168.0.1
	
	      routes:
	      - to: 192.168.1.0/24
	        via: 192.168.0.1

配置保存后,通过下面命令生效

	netplan apply

Ubuntu - network-manager

编辑network/interfaces文件,我们需要编辑网络接口和IP地址的配置文件。打开终端并运行以下命令:

sudo nano /etc/network/interfaces

在文件的底部添加以下行:

up route add -net 192.168.1.0/24 gw 192.168.0.1 dev eth0

这个命令添加了一个到网关192.168.0.1的路由,并将流量发送到eth0网络接口。

保存配置文件后,重启网络服务以使更改生效。运行以下命令:

sudo service network-manager restart

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/275314.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用机器学习进行语法错误检测/纠正

francescofranco_39234 一、说明 一般的学习&#xff0c;特别是深度学习&#xff0c;促进了自然语言处理。各种模型使人们能够执行机器翻译、文本摘要和情感分析——仅举几个用例。今天&#xff0c;我们将研究另一个流行的用途&#xff1a;我们将使用Gramformer构建一个用于机器…

安卓全球定位系统RTK测量仪 手持GPS北斗定位仪可用于国土电力

RTK&#xff0c;英文全名叫做Real-time kinematic&#xff0c;也就是实时动态。这是一个简称&#xff0c;全称是RTK&#xff08;Real-time kinematic&#xff0c;实时动态&#xff09;载波相位差分技术。 RTK定位是一种高精度的全球卫星导航技术&#xff0c;是实时运用技术&…

springcloud之通过openfeign优化服务调用方式

写在前面 源码 。 在前面的文章中我们实际上已经完成了优惠券模块微服务化的改造&#xff0c;但是其中还是有比较多可以优化和增强的地方&#xff0c;本文就先来对服务间的通信方式进行优化&#xff0c;具体就是使用openfeign来替换调原来的webclient。下面我们就开始吧&#…

低代码平台在金融银行中的应用场景

随着数字化转型的推进&#xff0c;商业银行越来越重视技术在业务发展中的作用。在这个背景下&#xff0c;白码低代码平台作为一种新型的开发方式&#xff0c;正逐渐受到广大商业银行的关注和应用。白码低代码平台能够快速构建各类应用程序&#xff0c;提高开发效率&#xff0c;…

网络攻防中应该掌握的进阶工具udp2raw,通过raw socket给UDP包加上TCP或ICMP header,进而绕过UDP屏蔽或QoS

网络攻防中应该掌握的进阶工具udp2raw,通过raw socket给UDP包加上TCP或ICMP header,进而绕过UDP屏蔽或QoS。 udp2raw tunnel,通过raw socket给UDP包加上TCP或ICMP header,进而绕过UDP屏蔽或QoS,或在UDP不稳定的环境下提升稳定性。可以有效防止在使用kcptun或者finalspeed的…

TiDB 7.5 LTS 发版丨提升规模化场景下关键应用的稳定性和成本的灵活性

互联网时代&#xff0c;数据的迅猛增长给数据库带来了可扩展性的挑战&#xff0c;Gen AI 带来的数据暴增更加剧了这种挑战。传统的数据分片已经不能承载新时代数据暴增的需求&#xff0c;更简单且具有前瞻性的方法则是采用原生分布式数据库来解决扩展性问题。在这种规模化场景的…

MYSQL一一外键约束

概念&#xff1a;外键用来让两张表的数据之间建立联系&#xff0c;从而保证数据的一致性和完整性 建立外键&#xff1a; ①这是在建立表的时候建立外键的方法 ②这是在建立完表之后建立外键的方法&#xff1a; 删除外键&#xff1a; 现在有一张员工表&#xff08;emp&#xf…

Linux基本指令(二)

目录 &#x1f4d5;前言 &#x1f4d5;echo 输出重定向&#xff08;>&#xff09; 追加重定向(>>) 输入重定向&#xff08;<&#xff09; &#x1f4d5;more &#x1f4d5;less &#x1f4d5;head &#x1f4d5;tail 查看大文本的中间部分 &#x1f4d5…

Java 8 中的 Stream 轻松遍历树形结构!

可能平常会遇到一些需求&#xff0c;比如构建菜单&#xff0c;构建树形结构&#xff0c;数据库一般就使用父id来表示&#xff0c;为了降低数据库的查询压力&#xff0c;我们可以使用Java8中的Stream流一次性把数据查出来&#xff0c;然后通过流式处理&#xff0c;我们一起来看看…

深入ArkUI:深入实战组件text和text input

文章目录 Text组件介绍Text组件的属性方法Text:文本显示组件4.3TextInput组件实战案例:图片宽度控制页面本文总结要点回顾在今天的课程中,我们将深入学习ArkUI提供的基础组件,着重探讨text和text input两个组件。 Text组件介绍 Text组件是一个用于显示文本的组件,其主要作…

自动化运维平台Spug本地部署结合内网穿透实现远程访问

文章目录 前言1. Docker安装Spug2 . 本地访问测试3. Linux 安装cpolar4. 配置Spug公网访问地址5. 公网远程访问Spug管理界面6. 固定Spug公网地址 前言 Spug 面向中小型企业设计的轻量级无 Agent 的自动化运维平台&#xff0c;整合了主机管理、主机批量执行、主机在线终端、文件…

【HTML】使用canvas添加水印

效果 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>添加水印</title><style>…

WebRTC原理与web端实战开发

什么是WebRTC webRtc(web real-time Communication) &#xff0c;旨在建立一个浏览器间实时通信的平台 谷歌开源跨平台&#xff08;android&#xff0c;IOS&#xff0c;windows&#xff0c;Linux&#xff09;实时传输&#xff08;提供强大的音视频引擎&#xff09; RTC涉及的…

SpringCloud(H版alibaba)框架开发教程---附源码 一

源码地址&#xff1a;https://gitee.com/jackXUYY/springboot-example 创建订单服务&#xff0c;支付服务&#xff0c;公共api服务&#xff08;共用的实体&#xff09;&#xff0c;eureka服务 1.cloud-consumer-order80 2.cloud-provider-payment8001 3.cloud-api-commons 4.…

Vue框架引入Axios

首先已经创建好了 Vue 框架&#xff0c;安装好了 node.js。 没有完成的可按照此博客搭建&#xff1a;搭建Vue项目 之后打开终端&#xff0c;使用命令。 1、命令安装 axios 和 vue-axios npm install axios --save npm install vue-axios --save2、package.json 查看版本 在 p…

Flink1.17实战教程(第五篇:状态管理)

系列文章目录 Flink1.17实战教程&#xff08;第一篇&#xff1a;概念、部署、架构&#xff09; Flink1.17实战教程&#xff08;第二篇&#xff1a;DataStream API&#xff09; Flink1.17实战教程&#xff08;第三篇&#xff1a;时间和窗口&#xff09; Flink1.17实战教程&…

新建虚拟环境并与Jupyter内核连接

第一步:在cmd里新建虚拟环境,shap38是新建的虚拟环境的名字 ,python=3.x conda create -n shap38 python=3.8第二步,安装ipykernel,打开anconda powershell prompt: 虚拟环境的文件夹位置,我的如图所示: 进入文件夹并复制地址: 输入复制的文件夹地址更改文件夹:…

跨境电商获客脚本必备功能有哪些?

随着全球化的加速和电子商务的兴起&#xff0c;跨境电商已经成为了企业拓展市场、提高收益的重要途径。 而在跨境电商运营中&#xff0c;获客脚本的作用不可忽视&#xff0c;本文将为您揭示跨境电商获客脚本必备的五大功能&#xff0c;帮助您在激烈的市场竞争中抢占先机。 一…

基于零和收益的DEA模型研究python实现

传统的DEA模型往往假设相关的是相互独立的,此时DEA模型只能计算出相对效率,无法进行效率的调整。如在碳排放分配问题上,碳排放总量保持不变,利用DEA模型只能计算出每个省份分配的相对效率,这在讨论固定资源下的碳排放配额分配问题时具有明显的局限性。在这种情况下,利用Z…

网络拓扑图怎么画最好?

画拓扑图的方式有很多&#xff0c;在线软件&#xff0c;Visio&#xff0c;PPT&#xff0c;都是方法。 问题是你要怎么从0到1&#xff0c;怎么样用拓扑图完美地把你的网络逻辑结构、思路呈现出来。 没经验的朋友真的不知道从哪里上手。 今天就给你来一篇绘制拓扑图详解&#…