首页 > 技术文章 > centos网络配置

liuyuanq 2018-11-30 23:27 原文

Linux网络属性管理(1)

 	局域网:以太网,令牌环网

 		Ethernet: CSMA/CD
 			冲突域
 			广播域  

 			MAC:Media Access Control
 				48bits: 
 					24bits:
 					24bits:

 			IP: Internet Protocol
 				Routing protocol
 				Routed protocol

OSI:
	OSI中的层	功能									TCP/IP协议族
	应用层		文件传输,电子邮件,文件服务,虚拟终端	TFTP,HTTP,SNMP,FTP,SMTP,DNS,Telnet
	表示层		数据格式化,代码转换,数据加密			没有协议
	会话层		解除或建立与别的接点的联系				没有协议
	传输层		提供端对端的接口						TCP,UDP
	网络层		为数据包选择路由						IP,ICMP,RIP,OSPF,BGP,IGMP
	数据链路层	传输有地址的帧以及错误检测功能			SLIP,CSLIP,PPP,ARP,RARP,MTU
	物理层		以二进制数据形式在物理媒体上传输数据	ISO2110,IEEE802,IEEE802.2

 	tcp/ip分层协议栈:物理层,互联网层,传输层,应用层
 			application layer 
 			transport layer	
 			internet layer	
 			datalink layer
 			pysical layer 


 		ip协议:网络号+主机号

 			IPv4 地址分类:32bits
 				8bits.8bits.8bits.8bits
 				点分十进制:0-255
 					0000 0000 - 1111 1111
 					0.0.0.0-255.255.255.255

 				A类:
 					0 000 0000 - 0 111 1111: 1-127
 					网络数量:126, 127
 					每个网络中的主机数:2^24-2
 					默认子网掩码:255.0.0.0  //用于与ip地址进行"与"运算,从而取出其网络地址
 						1.3.2.2/255.0.0.0 = 1.0.0.0
 					私网地址:10.0.0.0/255.0.0.0/8

 				B类:
 					10 00 0000 - 10 11 1111:128-191
 					网络数:2^14
 					每个网络中的主机数:2^16-2
 					默认子网掩码:255.255.0.0
 					私网地址:172.16.0.0/16-172.31.0.0/16

 				C类:
 					110 0 0000 - 110 1 1111: 192-223
 					网络数:2^21
 					每个网络中的主机数:2^8-2=254
 					默认子网掩码:255.255.255.0
 					私网地址:192.168.0.0/24-192.168.255.0/24

 				D类:组播
 					1110 0000 - 1110 1111: 224-239

 				E类:科研
 					240-255

 			子网掩码:
 				172.16.100.100/255.255.0.0, 172.17.1.1
 			
 			ipv6:128bits

 			跨网络通信:路由router
 					路由表:
 						静态指定
 						动态学习: rip2,ospf
 					路由条目:
 						目标地址 吓一跳(nexthop)
 							目标地址的类别:
 								主机:主机路由host
 								网络:网络路由net
 								0.0.0.0 /0.0.0.0 :默认路由

 	os: 多任务,多用户,多进程
 		通信时,进程的数字标识;
 			16bits:
 				0-65535
 					1-1023: 固定分配,而且只有管理员有权限启用;
 					1024-4w :半固定;
 					4w+: 临时;
 		进程地址:
 			ip:port,socket

	将Linux主机接入到网络中:
		IP/netmask: 本地通信
		路由(网关):跨网络通信
		DNS服务器地址: 基于主机名的通信
			主DNS服务器
			次(备用)DNS服务器
			第三DNS服务器

		配置方式:
			静态指定:
				ifcfg: 
					ifconfig:配置IP,netmask 
					route:路由
					netstat:状态及统计数据查看
				iproute2家族:
					ip OBJECT:
						addr:地址和掩码;
						link:接口
						route:路由
					ss:状态及统计数据查看
						
				配置文件:
					redhat及相关发行版:
						/etc/sysconfig/network-scripts/ifcfg-网卡名

				CentOS 7:nm(network manager)家族
					nmcli:命令行工具
					nmtui:text window 工具

				注意:
					(1)DNS服务器指定
						配置文件: /etc/resolv.conf
					(2)本地主机名配置
						hostname
						配置文件:/etc/sysconfig/network
						centos7 : hostnamectl

			动态分配:依赖于本地网络中有DHCP服务
				DHCP: Dynamic Host Configuration Protocol
	网络接口命名方式:
		传统命令:
			以太网:eth0,eth1,...
			ppp网络:ppp[0,1,2,...]

		可预测命令方案(centos):
			支持多种不同的命名机制:
				fireware,拓扑结构

			1) Firmware或BIOS为主板上集成的设备提供的索引信息可用,则根据此索引进行命名,如eno1,eno2, …
			2) Firmware或BIOS为PCI-E扩展槽所提供的索引信息可用,且可预测,则根据此索引进行命名,如ens1,ens2, …
			3) 如果硬件接口的物理位置信息可用,则根据此信息命名,如enp2s0, …
			4) 如果用户显式定义,也可根据MAC地址命名,例如eno16777736(十六进制MAC), …
			5)上述均不可用,则仍使用传统方式命名;

		命名格式的组成:
		    en:ethernet,表示因特网网卡接口
		    wl:wlan,表示无线网网卡接口
		    ww:wwan,Wireless Wide Area Network,表示无线广域网网卡

		    名称类型:
			   o<index>:集成设备的设备索引号;
			   s<slot>:扩展槽的索引号;
			   x<MAC>:基于MAC地址的命名;
			   p<bus>s<slot>:基于总线及槽的拓扑结构进行命名;

Linux网络属性配置(2)
		ifcfg家族:
			ifconfig命令:接口及地址查看
				ifconfig [interface]
					# ifconfig -a显示所有接口,包括inactive状态接口;
					# ifconfig IFACE(网卡名) [up|down]
       			ifconfig interface [aftype] options | address ...
       				# ifconfig IFACE IP/mask [up]
       					eg: ifconfig eth1 192.168.10.1/24 up
       				# ifconfig IFACE IP netmask MASK
       					eg: ifconfig eth1 192.168.10.101 netmask 255.255.255.0
       				
       				注意:立即生效;送往内核中的tcp/ip协议栈,并生效;

       				options:
       					启用混杂模式:[-]promisc

       		route命令:路由查看及管理
       			路由条目类型:
       				主机路由:目标地址为单个ip; host
       				网络路由:目标地址为ip网络; net
       				默认路由:目标为本地主机; 0.0.0.0/0.0.0.0
       			路由管理命令
       				查看:route -n   ;-n为反解,以数字显示IP和端口;
       				添加:route add
       					route add  [-net|-host]  target [netmask Nm] [gw Gw] [[dev] Iface]

       						目标des:192.168.0.0  网关gw:192.168.73.3(需要和自己主机在同一个网段)
       						~]# route add -host 192.168.0.0/16 gw 192.168.73.3 dev eth0

       						目标:192.168.0.0 网关:196.168.73.0
       						~]# route add -net 192.168.0.0 netmask 255.255.255.0 gw 196.168.73.0 dev eth0
       						~]# route add -net 192.168.0.0/24 gw 192.168.73.0 dev eth0

       						默认路由,网关:196.168.73.0
       						~]# route add -net 0.0.0.0 netmask 0.0.0.0 gw 196.168.73.0
       						~]# route add default gw 196.168.73.0

       						注意:gw 0.0.0.0 表示不用网关即默认网关,就在自己的本机上,无需网关;
       				删除:route del
       					route del [-net|-host] target [gw Gw] [netmask Nm] [[dev] If]

       						目标:192.18.0.0 网关:172.16.0.1
       						~]# route del -net 192.18.0.0 netmask 255.255.255.0 gw 172.16.0.1

    DNS服务器指定
       	/etc/resolv.conf
       		nameserver DNS_SERVER_IP1(数字地址ip)
       		nameserver DNS_SERVER_IP2
       		nameserver DNS_SERVER_IP3(最多三个)

       		如何测试:
       			正解:FQDN-->IP
       					# dig -t A FQDN(主机名)
       						fqdn-->ip
       					# host -t A FQDN
       			反解:IP-->FQDN
       					# dig -x IP
       					# host -t PTR IP
       					
       				FQDN: www.magedu.com.

       			netstat命令:
       				netstat - Print network connections, routing tables, interface statistics, masquerade connections, and multicast memberships

       				显示网络连接:
       					netstat [--tcp|-t] [--udp|-u] [--raw|-w] [--listening|-l] [--all|-a] [--numeric|-n] [--extend|-e[--extend|-e]]  [--program|-p]
       						-t: --tcp协议相关 ; 通信开始之前,需建立一个虚链路;通信完成后还要拆除连接;
       						-u: --udp协议相关 ; 直接发送数据报文;
       						-w: raw socket相关
       						-l: 处于监听状态
       						-a: 所有状态
       						-n: 以数字显示IP和端口;
       						-e:扩展格式
       						-p: 显示相关进程及PID

       						常用组合:
       							-tan, -uan, -tnl, -unl,-tunlp

       				显示路由表:
       					netstat  {--route|-r} [--numeric|-n]
       						-r: 显示内核路由表
       						-n: 数字格式
       					~]# netstat -rn

       				显示接口统计数据:
       					netstat  {--interfaces|-I|-i} [iface] [--all|-a] [--extend|-e] [--program|-p] [--numeric|-n] 

       						# netstat -i
       						# netstat -I IFACE  

       		总结:ifcfg家庭命令配置
       			ifconfig/route/netstat
       			ifup/ifdown

Linux网络配置(3)
	
	配置Linux网络属性:ip命令
	iproute家族:
		ip命令:
			ip - show / manipulate routing, devices, policy routing and tunnels

			ip [ OPTIONS ] OBJECT { COMMAND | help }

				OBJECT := { link | addr | route }

			ip OBJECT:
				ip link - network device configuration

					ip link set
						dev IFACE(default): 指明要管理的设备,dev关键字可省略;
						up and down:激活或禁用指定接口;
						multicast on 或 multicast off: 启用或禁用多播功能
						name NAME: 重命名接口
						mtu NUMBER : 设置mtu的大小,默认为1500
						netns PID : ns为namespace,用于将接口移动到指定的网络名称空间;

					ip link show 
					ip link help

				ip netns : ip - manage network namespaces

					ip netns list : 列出所有的netns
					ip netns add name : 创建指定netns
					ip netns del name : 删除指定的netns
					ip netns exec name cmd : 在指定的netns 中运行命令

				ip address - protocol address management管理接口地址

					ip addr { add | del } IFADDR dev STRING
						[label LABEL]:添加地址时指明网卡别名
						[scope {global|link|host}]:指明作用域
							global: 全局可用;
							link: 仅链接可用;
							host: 本机可用;
						[broadcast ADDRESS]:指明广播地址

					ip address show - look at protocol addresses
						[dev DEVICE]
						[label PATTERN]
						[primary and secondary]

					ip address flush - flush protocol addresses 清空
						使用格式同show

				ip route - routing table management

					ip route add
						添加路由:ip route add TARGET via GW dev IFACE src SOURCE_IP
							TARGET:
								主机路由:IP
								网络路由:NETWORK/MASK

							添加网关:ip route add defalt via GW dev IFACE

					ip route delete
						删除路由:ip route del  TARGET 

					ip route show
					ip route flush
						[dev IFACE]
						[via PREFIX]

		ss命令:another utility to investigate sockets
			格式:ss [OPTION]... [FILTER]
				选项:
					-t: tcp协议相关
					-u: udp协议相关
					-w: 裸套接字相关
					-x:unix sock相关
					-l: listen状态的连接
					-a: 所有
					-n: 数字格式
					-p: 相关的程序及PID
					-e: 扩展的信息
					-m:内存用量
					-o:计时器信息

					FILTER := [ state TCP-STATE ] [ EXPRESSION ]

			TCP的常见状态:
				tcp finite state machine:
					LISTEN: 监听
					ESTABLISHED:已建立的连接
					FIN_WAIT_1
					FIN_WAIT_2
					SYN_SENT
					SYN_RECV
					CLOSED

				EXPRESSION:
					dport = 
					sport = 
					示例:’( dport = :ssh or sport = :ssh )’

			常用组合:
				-tan, -tanl, -tanlp, -uan

Linux网络属性配置(4): 修改配置文件

		IP、MASK、GW、DNS相关配置文件:/etc/sysconfig/network-scripts/ifcfg-IFACE
		路由相关的配置文件:/etc/sysconfig/network-scripts/route-IFACE

		/etc/sysconfig/network-scripts/ifcfg-IFACE:
			[root@centos7-1 network-scripts]#  cat ifcfg-ens33
			TYPE="Ethernet"
			PROXY_METHOD="none"  //
			BROWSER_ONLY="no"
			BOOTPROTO="dhcp"
			DEFROUTE="yes"  //是否使用默认路由
			IPV4_FAILURE_FATAL="no"  //ipv4出错时是否使用ipv6
			IPV6INIT="yes"
			IPV6_AUTOCONF="yes"
			IPV6_DEFROUTE="yes"
			IPV6_FAILURE_FATAL="no"
			IPV6_ADDR_GEN_MODE="stable-privacy"
			NAME="ens33"
			UUID="795f0d4a-6e0b-492b-b145-08f1eebf10cb"
			DEVICE="ens33"
			ONBOOT="yes"
		解释:
			DEVICE:此配置文件应用到的设备;与IFACE一致;
			HWADDR:对应的设备的MAC地址;
			BOOTPROTO:激活此设备时使用的地址配置协议,常用的dhcp, static, none, bootp;
			NM_CONTROLLED:NM是NetworkManager的简写;此网卡是否接受NM控制;CentOS6建议为“no”;
			ONBOOT:在系统引导时是否激活此设备;
			TYPE:接口类型;常见有的Ethernet, Bridge;
			UUID:设备的惟一标识;
			IPV6INIT: 是否初始化IPv6;

			IPADDR:指明IP地址;
			NETMASK:子网掩码;PREFIX
			GATEWAY: 默认网关;
			DNS1:第一个DNS服务器指向;
			DNS2:第二个DNS服务器指向;

			USERCTL:普通用户是否可控制此设备;
			PEERDNS:如果BOOTPROTO的值为“dhcp”,是否允许dhcp server分配的dns服务器指向信息直接覆盖至/etc/resolv.conf文件中;默认允许即yes;
			NM_CONTROLLED: 是否使用networkmanger服务来控制接口;

		网络服务:
		 	network
		 	networkmanger

		管理网络服务:
			centos6 : service network { status | restart | start | stop }
			centos7 : systemctl  { status | restart | start | stop } network[.service]

		配置文件修改之后,需重启网络服务,配置文件才生效;
			重启方法见管理网络服务;

		/etc/sysconfig/network-scripts/route-IFACE
			两种风格:不可混用
				(1) 每行一个路由条目
					TARGET via GW

				(2) 每三行定义一条路由
					ADDRESS#=TARGET
					NETMASK#=mask
					GATEWAY#=GW

		给网卡配置多地址:
			ifconfig:
				ifconfig IFACE_ALIAS 
			ip
				ip addr add 
			配置文件:
				ifcfg-IFACE_ALIAS
					DEVICE=IFACE_ALIAS

			注意:网关别名不能使用dhcp协议引导;

	Linux网络属性配置的tui(text user interface):
		system-config-network-tui

		也可以使用setup找到;

		注意:记得重启网络服务方能生效;

	配置当前主机的主机名:
		hostname [HOSTNAME]

		/etc/sysconfig/network
		HOSTNAME=

	网络接口识别并命名相关的udev配置文件:
		/etc/udev/rules.d/70-persistent-net.rules

		卸载网卡驱动:
			modprobe -r e1000

		装载网卡驱动:
			modprobe e1000


	CentOS 7网络属性配置

		传统命名:以太网eth[0,1,2,...], wlan[0,1,2,...]

		可预测功能

			udev支持多种不同的命名方案:
				Firmware, 拓扑结构

		(1) 网卡命名机制
			systemd对网络设备的命名方式:
				(a) 如果Firmware或BIOS为主板上集成的设备提供的索引信息可用,且可预测则根据此索引进行命名,例如eno1;
				(b) 如果Firmware或BIOS为PCI-E扩展槽所提供的索引信息可用,且可预测,则根据此索引进行命名,例如ens1; 
				(c) 如果硬件接口的物理位置信息可用,则根据此信息进行命名,例如enp2s0;
				(d) 如果用户显式启动,也可根据MAC地址进行命名,enx2387a1dc56; 
				(e) 上述均不可用时,则使用传统命名机制;

				上述命名机制中,有的需要biosdevname程序的参与;

		(2) 名称组成格式
			en: ethernet
			wl: wlan
			ww: wwan

			名称类型:
				o<index>: 集成设备的设备索引号;
				s<slot>: 扩展槽的索引号;
				x<MAC>: 基于MAC地址的命名;
				p<bus>s<slot>: enp2s1

		网卡设备的命名过程:
			第一步:
				udev, 辅助工具程序/lib/udev/rename_device, /usr/lib/udev/rules.d/60-net.rules

			第二步:
				biosdevname 会根据/usr/lib/udev/rules.d/71-biosdevname.rules

			第三步:
				通过检测网络接口设备,根据/usr/lib/udev/rules.d/75-net-description
					ID_NET_NAME_ONBOARD, ID_NET_NAME_SLOT, ID_NET_NAME_PATH

		回归传统命名方式:
			(1) 编辑/etc/default/grub配置文件
				GRUB_CMDLINE_LINUX="net.ifnames=0 rhgb quiet"

			(2) 为grub2生成其配置文件
				grub2-mkconfig -o /etc/grub2.cfg

			(3) 重启系统

		地址配置工具:nmcli
			nmcli  [ OPTIONS ] OBJECT { COMMAND | help }

				device - show and manage network interfaces

				connection - start, stop, and manage network connections

			如何修改IP地址等属性:
				#nmcli connection modify IFACE [+|-]setting.property value
					 setting.property:
					 	ipv4.addresses
					 	ipv4.gateway
					 	ipv4.dns1
					 	ipv4.method
					 		manual

		网络接口配置tui工具:nmtui

		主机名称配置工具:hostnamectl
			status
			set-hostname

	博客作业:上述所有内容;
		ifcfg, ip/ss, 配置文件, nmcli

	参考资料:http://www.redhat.com/hdocs

	课外作业:nmap, ncat, tcpdump工具

	网络客户端工具:
		lftp, ftp, lftpget, wget

			# lftp [-p port] [-u user[,password]] SERVER
				子命令:
					get
					mget
					ls
					help

			# lftpget URL

			# ftp

			# wget
				wget [option]... [URL]...
					-q: 静默模式
					-c: 续传
					-O: 保存位置
					--limit-rates=: 指定传输速率

			
回顾:ip命令,ss命令;配置文件;CentOS 7

	ifcfg、ip、netstat、ss
	配置文件:
		/etc/sysconfig/network-scripts/
			ifcfg-IFNAME
			route-IFNAME
	CentOS 7: nmcli, nmtui

  

推荐阅读