Linux 网络设置命令
即时生效(重启后失效):
ifconfigeth0192.168.1.102netmask255.255.255.0//添加IP地址
routeadddefaultgw192.168.1.1//添加网关
启动生效:
vim/etc/sysconfig/network-scripts/ifcfg-eth0//(某些版本中可能没有vim这个编辑器比如centos,大家可能用vi替换)
IPADDR=192.168.1.102//添加IP地址
NETMASK=255.255.255.0//掩码
GATEWAY=192.168.1.1//添加网关
最后结果如下:
DEVICE=eth0
BOOTPROTO=static
IPADDR=192.168.1.102
NETMASK=255.255.255.0
GETEWAY=192.168.1.1
ONBOOT=yes
TYPE=Ethernet
注:BOOTPROTO只有在static(静态)模式下才可以使用设置的IP信息
修改dns
vim/etc/resolv.conf
修改后可即时生效,启动同样有效
形式
加入nameserver=***.***.***.***
最多可有三个,作为上一个失败后的候选
修改hostname
即时生效:
hostnamefc2
启动生效:
vim/etc/sysconfig/network
形式如下:
NETWORKING=yes
HOSTNAME=rh-linux.fc.org
##########################################################
首先,先了解传统的网络配置命令:
1.使用ifconfig命令配置并查看网络接口情况
示例1:配置eth0的IP,同时激活设备:
ifconfigeth0192.168.4.1netmask255.255.255.0up
示例2:配置eth0别名设备eth0:1的IP,并添加路由
ifconfigeth0:1192.168.4.2
routeadd–host192.168.4.2deveth0:1
示例3:激活(禁用)设备
ifconfigeth0:1up(down)
示例4:查看所有(指定)网络接口配置
ifconfig(eth0)
—————————
2.使用route命令配置路由表
示例1:添加到主机路由
routeadd–host192.168.4.2deveth0:1
routeadd–host192.168.4.1gw192.168.4.250
示例2:添加到网络的路由
routeadd–netIPnetmaskMASKeth0
routeadd–netIPnetmaskMASKgwIP
routeadd–netIP/24eth1
示例3:添加默认网关
routeadddefaultgwIP
示例4:删除路由
routedel–host192.168.4.1deveth0:1
示例5:查看路由信息
route或 route-n (-n表示不解析名字,列出速度会比route快)
—————————
3.ARP管理命令
示例1:查看ARP缓存
arp
示例2: 添加
arp–sIPMAC
示例3:删除
arp–dIP
—————————
4. ip是iproute2软件包里面的一个强大的网络配置工具,它能够替代一些传统的网络管理工具。
例如:ifconfig、route等,
上面的示例完全可以用下面的ip命令实现,而且ip命令可以实现更多的功能.下面介绍一些示例:
4.0ip命令的语法
ip[OPTIONS]OBJECT[COMMAND[ARGUMENTS]]
4.1iplinkset–改变设备的属性. 缩写:set、s
示例1:up/down起动/关闭设备。
iplinksetdeveth0up
这个等于传统的
ifconfigeth0up
ifconfigeth0down
示例2:改变设备传输队列的长度。
参数:txqueuelenNUMBER或者txqlenNUMBER
iplinksetdeveth0txqueuelen100
示例3:改变网络设备MTU(最大传输单元)的值。
iplinksetdeveth0mtu1500
示例4:修改网络设备的MAC地址。
参数:addressLLADDRESS
iplinksetdeveth0address00:01:4f:00:15:f1
4.2iplinkshow–显示设备属性. 缩写:show、list、lst、sh、ls、l
-s选项出现两次或者更多次,ip会输出更为详细的错误信息统计。
示例:
ip-s-slinklseth0
这个命令等于传统的
ifconfigeth0
—————————
5.1ipaddressadd–添加一个新的协议地址.缩写:add、a
示例1:为每个地址设置一个字符串作为标签。为了和Linux-2.0的网络别名兼容,这个字符串必须以设备名开头,接着一个冒号,
ipaddraddlocal192.168.4.1/28brd+labeleth0:1deveth0
等价于
ifconfigeth0:5192.168.4.1/28
ipaddraddlocal192.168.4.1/28deveth0
示例2:在以太网接口eth0上增加一个地址192.168.20.0,掩码长度为24位(155.155.155.0),标准广播地址,标签为eth0:Alias:
ipaddradd192.168.4.2/24brd+deveth1labeleth1:1
这个命令等于传统的:
ifconfigeth1:1192.168.4.2/24
5.2ipaddressdelete–删除一个协议地址.缩写:delete、del、d
ipaddrdel192.168.4.1/24brd+deveth0labeleth0:Alias1
5.3ipaddressshow–显示协议地址.缩写:show、list、lst、sh、ls、l
ipaddrlseth0
5.4.ipaddressflush–清除协议地址.缩写:flush、f
示例1:删除属于私网10.0.0.0/8的所有地址:
ip-s-safto10/8
示例2:取消所有以太网卡的IP地址
ip-4addrflushlabel“eth0″
—————————
6.ipneighbour–neighbour/arp表管理命令
缩写neighbour、neighbor、neigh、n
命令add、change、replace、delete、fulsh、show(或者list)
6.1ipneighbouradd—添加一个新的邻接条目
ipneighbourchange–修改一个现有的条目
ipneighbourreplace–替换一个已有的条目
缩写:add、a;change、chg;replace、repl
示例1:在设备eth0上,为地址10.0.0.3添加一个permanentARP条目:
ipneighadd10.0.0.3lladdr0:0:0:0:0:1deveth0nudperm
示例2:把状态改为reachable
ipneighchg10.0.0.3deveth0nudreachable
6.2.ipneighbourdelete–删除一个邻接条目
示例1:删除设备eth0上的一个ARP条目10.0.0.3
ipneighdel10.0.0.3deveth0
6.3.ipneighbourshow–显示网络邻居的信息. 缩写:show、list、sh、ls
示例1:ip-snls193.233.7.254
193.233.7.254.deveth0lladdr00:00:0c:76:3f:85ref5used12/13/20nudreachable
6.4.ipneighbourflush–清除邻接条目.缩写:flush、f
示例1:(-s可以显示详细信息)
ip-s-snf193.233.7.254
—————————
7.路由表管理
7.1.缩写route、ro、r
7.5.路由表
从Linux-2.2开始,内核把路由归纳到许多路由表中,这些表都进行了编号,编号数字的范围是1到255。另外,
为了方便,还可以在/etc/iproute2/rt_tables中为路由表命名。
默认情况下,所有的路由都会被插入到表main(编号254)中。在进行路由查询时,内核只使用路由表main。
7.6.iprouteadd—添加新路由
iproutechange—修改路由
iproutereplace—替换已有的路由
缩写:add、a;change、chg;replace、repl
示例1:设置到网络10.0.0/24的路由经过网关193.233.7.65
iprouteadd10.0.0/24via193.233.7.65
示例2:修改到网络10.0.0/24的直接路由,使其经过设备dummy
iproutechg10.0.0/24devdummy
示例3:实现链路负载平衡.加入缺省多路径路由,让ppp0和ppp1分担负载(注意:scope值并非必需,它只不过是告诉内核,这个路由要经过网关而不是直连的。实际上,如果你知道远程端点的地址,使用via参数来设置就更好了)。
iprouteadddefaultscopeglobalnexthopdevppp0nexthopdevppp1
iproutereplacedefaultscopeglobalnexthopdevppp0nexthopdevppp1
示例4:设置NAT路由。在转发来自192.203.80.144的数据包之前,先进行网络地址转换,把这个地址转换为193.233.7.83
iprouteaddnat192.203.80.142via193.233.7.83
示例5:实现数据包级负载平衡,允许把数据包随机从多个路由发出。weight可以设置权重.
iproutereplacedefaultequalizenexthopvia211.139.218.145deveth0weight1nexthopvia211.139.218.145deveth1weight1
7.7.iproutedelete–删除路由
缩写:delete、del、d
示例1:删除上一节命令加入的多路径路由
iproutedeldefaultscopeglobalnexthopdevppp0nexthopdevppp1
7.8.iprouteshow—列出路由
缩写:show、list、sh、ls、l
示例1:计算使用gated/bgp协议的路由个数
iproutelsprotogated/bgp|wc
1413 9891 79010
示例2:计算路由缓存里面的条数,由于被缓存路由的属性可能大于一行,以此需要使用-o选项
ip-oroutelscloned|wc
159 2543 18707
示例3:列出路由表TABLEID里面的路由。缺省设置是tablemain。TABLEID或者是一个真正的路由表ID或者是/etc/iproute2/rt_tables文件定义的字符串,
或者是以下的特殊值:
all—列出所有表的路由;
cache—列出路由缓存的内容。
iprols193.233.7.82tabcache
示例4:列出某个路由表的内容
iproutelstablefddi153
示例5:列出默认路由表的内容
iproutels
这个命令等于传统的:route
7.9.iprouteflush—擦除路由表
示例1:删除路由表main中的所有网关路由(示例:在路由监控程序挂掉之后):
ip-4roflushscopeglobaltypeunicast
示例2:清除所有被克隆出来的IPv6路由:
ip-6-s-sroflushcache
示例3: 在gated程序挂掉之后,清除所有的BGP路由:
ip-srofprotogated/bgp
示例4:清除所有ipv4路由cache
iprouteflushcache
***IPv4routingcacheisflushed.
7.10 ip route get — 获得单个路由 .缩写:get