课程目标
了解 OSI 七层模型分层结构
了解 TCP/IP 协议簇四层模型分层结构
能够说出 TCP/IP 协议簇中 运输层、网络层和数据链路 层常见的 相关协议
能够说出 TCP/IP 的三次握手四次断开过程
了解 Vmware 的三种网络模式
能够使用客户端工具连接虚拟机
掌握主机名、 DNS 和静态 IP 的配置
能够使用相关命令查看和配置主机网络信息 ,如 ifconfig/ip addr/route 等
思考:
数据在两台计算机之间是如何传输的?
数据传输过程:
一、OSI七层模型
1. 什么是OSI模型
OSI:
开放系统互连参考模型 , 是国际标准化组织 (ISO) 和国际电报电话咨询委员会 (CCITT) 联合制定的 开放系统互连参考
模型。
目的 : 为开放式互连信息系统提供了一种功能结构的框架和参考。 这里所说的开放系统,实质上指的是遵循 OSI 参考模型和相关协议能够实现互连的具有各种应用目的的计算机系
统。
OSI 采用了分层的结构化技术,共分七层:
物理层、数据链路层、网络层、传输层、会话层、表示层、应用层
2. OSI的七层介绍
2.1 应用层
1.应用层是计算机用户,以及各种应用程序和网络之间的接口,其功能是直接向用户提供服务,完成用户希望在 网络上完成的各种工作。
2.应用层为用户提供的 服务和协议 :文件传输服务( FTP )、远程登录服务( ssh )、网络管理服等。
3.上述的各种网络服务由该层的不同应用协议和程序完成。
应用层的主要功能如下:
用户接口 :应用层是用户与网络,以及应用程序与网络间的直接接口,使得用户能够与网络进行交互式联 系。
实现各种服务 :该层具有的各种应用程序可以完成和实现用户请求的各种服务。
2.2 表示层
表示层是 对来自应用层的命令和数据进行解释,对各种语法赋予相应的含义,并按照一定的格式传送给会话 层。
其主要功能是 处理用户信息的表示问题 ,如编码、数据格式转换和加密解密等。
表示层的具体功能如下:
数据格式处理:协商和建立数据交换的格式,解决各应用程序之间在数据格式表示上的差异。
数据的编码:处理字符集和数字的转换。
压缩和解压缩:为了减少数据的传输量,这一层还负责数据的压缩与解压缩。
数据的加密和解密:可以提高网络的安全性。
2.3 会话层
会话层是用户应用程序和网络之间的接口,主要任务是:组织和协调两个会话进程之间的通信,并对数据交换 进行管理。
当建立会话时,用户必须提供他们想要连接的远程地址。
2.4 传输层
OSI上 3 层:应用层、表示层、会话层的主要任务是数据处理 —— 资源子网
OSI下 3 层:网络层、数据链路层、物理层的主要任务是数据通讯 —— 通讯子网
传输层是OSI 模型的第 4 层,它是通信子网和资源子网的接口和桥梁,起到承上启下的作用
传输层的主要任务是:向用户提供可靠的端到端的差错和流量控制,保证报文的正确传输
报文: 报文 ( message ) 是网络中交换与传输的 1
报文段 : 组成报文的每个分组。我们将运输层分组称为报文段 ( segment )
2.5 网络层
主要任务是:数据链路层的数据在这一层被转换为 2 ,然后通过路径选择、分段组合、顺序、进 / 出路由等控 制,将信息从一个网络设备传送到另一个网络设备。
一般情况下,数据链路层是解决同一网络 ( 局域网 ) 内节点之间的通信,而网络层主要解决 不同子网 间的通信。
2.6 数据链路层
在计算机网络中由于各种干扰的存在,物理链路是不可靠的。因此,这一层的主要功能是 :
在物理层提供的比特流的基础上,通过差错控制、流量控制方法,使有差错的物理线路变为无差错的数据链 路,即 向网络层提供可靠的通过物理介质传输数据的方法 。
具体工作是:接收来自物理层的位流(比特流)形式的数据,通过差错控制等方法传到网络层;同样,也将来 自上层的数据,封装成 3 转发到物理层;并且,还负责处理接收端发回的确认帧的信息,以便提供可靠的数据
传输。
帧: 帧 ( frame ) 是数据链路层的传输单元。将上层传入的数据添加一个头部和尾部,组成了帧 .
2.7 物理层
主要功能是:利用传输介质为数据链路层提供物理连接,实现 比特流的透明传输 。尽可能屏蔽掉具体传输介质 和物理设备的差异。
3. 总结
在 7 层模型中,每一层都提供一个特殊的网络功能。
从网络功能的角度观察:
物理层、数据链路层、网络层:主要提供数据传输和交换功能 ,即节点到节点之间通信为主;
传输层(第4 层):作为上下两部分的桥梁,是整个网络体系结构中最关键的部分;
会话层、表示层和应用层:以提供用户与应用程序之间的信息和数据处理 功能为主;
二、TCP/IP协议模型
1. 什么是TCP/IP模型
TCP/IP协议模型 ( Transmission Control Protocol/Internet Protocol ),包含了一系列构成互联网 基础的网络 协议 ,是 Internet 的核心协议,通过 20 多年的发展已日渐成熟,并被广泛应用于 局域网和广域网 中,目前已成 为一种国际标准 。
TCP/IP协议簇是一组不同层次上的 多个协议 的组合,该协议采用了 4 层的层级结构,每一层都 呼叫 它的下一层所 提供的 协议 来完成自己的需求,与 OSI 的七层模型相对应。
尽管通常称该协议族为TCP/IP ,但 TCP 和 IP 只是其中的两种协议而已(该协议族的另一个名字是 Internet 协议族 (Internet Protocol Suite))
2. TCP/IP的分层结构
2.1 链路层
OSI 的物理层和数据链路层
ARP(地址解析协议 IP-MAC )和 RARP (逆地址解析协议 MAC-IP )是某些网络接口(如以太网)使用的特殊协 议,用来转换IP 层和网络接口层使用的地址。
2.2 网络层
也称作互联网层或网际层,处理分组在网络中的活动,例如分组的选路。
在TCP/IP 协议族中,网络层协议包括 IP 协议(网际协议), ICMP 协议( Internet 互联网控制报文协议),以及 IGMP协议( Internet 组管理协议)。
IP是一种网络层协议,提供的是一种不可靠的服务,它只是尽可能快地把分组从源结点送到目的结点,但是并不提供任何可靠性保证。同时被TCP 和 UDP 使用。
TCP和UDP 的每组数据都通过端系统和每个中间路由器中的 IP 层在互联网中进行传输。
ICMP是IP 协议的附属协议。 IP 层用它来与其他主机或路由器 交换错误报文和其他重要信息 。它主要是用来 提供有关通向目的地址的路径信息。Ping 和 Traceroute 工具,它们都使用了 ICMP 协议。
IGMP是Internet 组管理协议。它用来把一个 UDP 数据报多播到多个主机。该协议运行在主机和组播路由器 之间。
2.3 运输层
主要为两台主机上的应用程序提供端到端的通信。在 TCP/IP 协议族中,有两个互不相同的传输协议: TCP (传输控制协议)和 UDP (用户数据报协议) TCP 协议: 为两台主机提供高可靠性的数据通信。 TCP 是 面向连接 的通信协议,通过三次握手 建立连接,通讯完成时要断开连接,由于 TCP 是面向连接的所以只能用于端到端的通讯。 TCP提供的是一种可靠的数据流服务,采用 “ 带重传的肯定确认 ” 技术来实现传输的可靠性。也就是 TCP 数据包中包括 序号(seq )和确认( ack ),所以未按照顺序收到的包可以被排序,而损坏的包可以被重传。 UDP 协议: 则为应用
层提供一种非常简单的服务。它是 面向无连接 的通讯协议, UDP 数据包括目的端口号和源端口号信息,由于通讯不需 要连接,所以可以实现广播发送。 UDP 通讯时不需要接收方确认,不保证该数据报能到达另一端,属于不可靠的传 输,可能会出现丢包现象。UDP 与 TCP 位于同一层,但它不管数据包的顺序、错误或重发。
2.4 应用层
OSI 会话层、表示层、应用层
应用层负责处理特定的应用程序细节。
HTTP 、 FTP 、 SSH 、 DHCP 、 DNS.....
3. 数据封装过程
数据格式
TCP数据信息: TCP 头部 + 实际数据 (TCP 头包括源和目标主机 端口号 、顺序号、确认号、校验字等)
IP数据包: IP 头部 +TCP 数据信息( IP 头包括源和目标主机 IP 地址 、类型、生存期等)
数据帧:帧头+IP 数据包 + 帧尾 (帧头包括源和目标主机 MAC 初步地址 及类型,帧尾是校验字)
数据的封装与解封装: 封装:数据要通过网络进行传输,要从高层一层一层的向下传送,如果一个主机要传送 数据到别的主机,先把数据装到一个特殊协议报头中,这个过程叫----- 封装 。 解封装:上述的逆向过程
当数据以 TCP/IP 协议传输时的封装与街封装过程如下图:
三、TCP/IP三次握手四次断开
1. 了解相关名词
序列号: Seq 序号,占 32 位,用来标识从 TCP 源端向目的端发送的字节流,发起方发送数据时对此进行标记。确认序号: Ack 序号,占 32 位,只有 ACK 标志位为 1 时,确认序号字段才有效, Ack = Seq + 1 。常见的标志位:ACK :确认序号有效。SYN :发起一个新连接。FIN :释放一个连接。
2. 了解netstat中的网络状态
CLOSED 初始(无连接)状态。LISTEN 侦听状态,等待远程机器的连接请求。SYN_SEND在 TCP 三次握手中,主动连接端发送了 SYN 包后,进入 SYN_SEND 状态,等待对方的 ACK 包。SYN_RECV在 TCP 三次握手中,主动连接端收到 ACK 包后,进入 SYN_RECV 状态。ESTABLISHED完成 TCP 三次握手后,主动连接端进入 ESTABLISHED 状态。此时, TCP 连接已经建立,可以进行通信。FIN_WAIT_1 在 TCP 四次断开时,主动关闭端发送 FIN 包后,进入 FIN_WAIT_1 状态。FIN_WAIT_2 在 TCP 四次断开时,主动关闭端收到 ACK 包后,进入 FIN_WAIT_2 状态。TIME_WAIT 在 TCP 四次断开时,主动关闭端发送了 ACK 包之后,进入 TIME_WAIT 状态。CLOSE_WAIT 在 TCP 四次断开时,被动关闭端收到 FIN 包后,进入 CLOSE_WAIT 状态。LAST_ACK 在 TCP 四次断开时,被动关闭端发送 FIN 包后,进入 LAST_ACK 状态,等待对方的 ACK 包。
3. TCP/IP三次握手
TCP 三次握手的过程如下:1. 客户机 A 端(主动连接端)发送一个 SYN 包给服务器 B 端(被动连接端);2. 服务器 B 端(被动连接端)收到 SYN 包后,发送一个带 ACK 和 SYN 标志的包给客户机 A 端(主动连接端);3. 客户机 A 端(主动连接端)发送一个带 ACK 标志的包给服务器 B 端(被动连接端),握手动作完成。
4. TCP/IP四次断开
TCP四次断开的过程如下:
1. 客户机A端(主动连接端)发送一个FIN包给服务器B端(被动连接端)请求断开连接;
2. 服务器B端(被动连接端)收到FIN包后,发送一个ACK包给客户机A端(主动连接端);
3. 服务器B端(被动连接端)发送了ACK包后,再发送一个FIN包给客户机A端(主动连接端)确认断开;
4. 客户机A端(主动连接端)收到FIN包后,发送一个ACK包,当服务器B端(被动连接端)收到ACK包后,四次断开动作完
成,连接断开。
四、Vmware网络模式
1. 虚拟设备
VMnet0 :用于虚拟 桥接网络 下的 虚拟交换机VMnet1 :用于虚拟 Host-Only 网络 下的 虚拟交换机VMnet8 :用于虚拟 NAT 网络 下的 虚拟交换机VMware Network Adepter VMnet1 : Host 用于与 Host-Only 虚拟网络进行通信的虚拟网卡 VMwareNetwork Adepter VMnet8 : Host 用于与 NAT 虚拟网络进行通信的虚拟网卡
2. 三种网络模式
桥接网络
桥接网络是指虚拟网卡通过 VMnet0 虚拟交换机和本地物理网卡进行桥接,那么物理网卡和虚拟网卡就相 当于处于同一个网段,虚拟交换机就相当于一台现实网络中的交换机。所以要想虚拟机也可以连接到互联 网中,那么两个网卡的IP 地址也要设置为同一网段。
NAT网络
在 NAT 网络中,会用到 VMware Network Adepter VMnet8 虚拟网卡,主机上的 VMware Network Adepter VMnet8虚拟网卡被直接连接到 VMnet8 虚拟交换机上与虚拟网卡进行通信。 VMware Network Adepter VMnet8虚拟网卡的作用仅限于和 VMnet8 网段进行通信,它不给 VMnet8 网段提供路由功能,所 以虚拟机虚拟一个NAT 服务器,使虚拟网卡可以连 接到 Internet 。 VMware Network Adepter VMnet8虚拟网卡的 IP 地址是在安装 VMware 时由系统指定生成的,我们尽量不要修改这个数值,否则可 能会使主机和虚拟机无法通信。
Host-Only模式
在Host-Only模式下,虚拟网络是一个全封闭的网络,它唯一能够访问的就是物理真机。其实Host-Only
网络和NAT网络很相似,不同的地方就是Host-Only网络没有NAT服务,所以虚拟网络不能连接到
Internet。主机和虚拟机之间的通信是通过VMware Network Adepter VMnet1虚拟网卡来实现的。
五、主机网络配置
1. 常见的网络接口
2. 查看网络信息
查看 IP 、掩码、 MAC[root @node1 ~ ] # ip addr[root @node1 ~ ] # ip a只显示 eth0 的信息[root @node1 ~ ] # ip addr show eth0查看本机路由表信息 ( 默认网关,默认路由 )[root @node1 ~ ] # ip routedefault via 10.1.1.254 dev eth0查看 DNS[root @node1 ~ ] # cat /etc/resolv.confnameserver 119.29.29.29ifconfig 命令:1. 给网卡配置临时子接口# ifconfig eth0# ifconfig -a# ifconfig eth0:1 192.168.0.1 netmask 255.255.255.0注意:重启网络 | 系统失效2. 永久生效需要创建子配置文件# cp ifcfg-eth0 ifcfg-eth0:1# pwd/ etc / sysconfig / network-scripts[root @node1 network-scripts] # cat ifcfg-eth0:1DEVICE = eth0 : 1TYPE = EthernetONBOOT = yesBOOTPROTO = noneIPADDR = 192.168.0.1NETMASK = 255.255.255.0重启网络# service network restart3. 其他命令ifup eth0ifdown eth1ifconfig eth0 down / up
环境准备要求:
1. 还原 Centos6.9 和 Centos7.5 系统
2. 以 Centos6.9 系统为模板克隆 2 台虚拟机
3. 拿一台 Centos6.9 系统,增加一个网卡,网络模式为仅主机模式
4. 分别配置 Centos6.9 系统的网络
两张网卡的主机,分别配置 NAT 和仅主机模式 IP
其他两台主机,只配置仅主机模式的 IP( 一张网卡 )
3. 修改网络信息
方法 1 :
[root@node1 ~]# setup
方法 2 :
修改网卡配置文件[root @node1 ~ ] # cat /etc/sysconfig/network-scripts/ifcfg-eth0DEVICE = eth0TYPE = EthernetONBOOT = yesBOOTPROTO = noneIPADDR = 10.1.1.1NETMASK = 255.255.255.0++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++DEVICE = eth0 设备名TYPE = Ethernet 以太网BOOTPROTO = none IP 地址获取方式,静态 : static,none 动态 : dhcp,dynamicONBOOT = yes 重启网卡是否激活该网卡BROADCAST = 192.168.2.255 广播地址HWADDR = 00 : E0 : 4 C : 41 : 95 : DB MAC 地址NM_CONTROLLED = yes 是否接受 NetworkManager 管理IPADDR = 192.168.2.253 IP 地址PREFIX = 24 子网掩码 NETMASK = 255.255.255.0NETWORK = 192.168.2.0 网络地址GATEWAY = 192.168.2.254 默认网关DNS1 = 202.106.0.20 DNS 服务器DNS2 = 8.8.8.8 DNS 服务器备++++++++++++++++ 动态获取 IP(dhcp) +++++++++++++++DEVICE = eth0BOOTPROTO = dhcpONBOOT = yes
3.2 修改主机名
3.3 配置 DNS
[root @node2 ~ ] # cat /etc/resolv.confnameserver DNS 服务器nameserver 114.114.114.114nameserver 8.8.8.8nameserver 192.168.159.2直接修改网卡的配置文件 ifcfg-eth0 :....DNS1 = 202.106.0.20 DNS 服务器DNS2 = 8.8.8.8 DNS 服务器备
4. 关闭防火墙和selinux
Centos6.5:
临时关闭:
[root@node2 ~]# service iptables stop
iptables: Setting chains to policy ACCEPT: filter [ OK ]
iptables: Flushing firewall rules: [ OK ]
iptables: Unloading modules: [ OK ][root@node2 ~]# service iptables status
iptables: Firewall is not running.
[root@node2 ~]#
开机自动关闭:
[root@node2 ~]# chkconfig --list|grep iptables
iptables 0:off 1:off 2:on 3:on 4:on 5:on 6:off
[root@node2 ~]# chkconfig iptables off
关闭selinux:
[root@node2 ~]# getenforce
Enforcing
[root@node2 ~]# setenforce
usage: setenforce [ Enforcing | Permissive | 1 | 0 ]
[root@node2 ~]# setenforce 0 临时变成警告模式
[root@node2 ~]# getenforce
Permissive
[root@node2 ~]# cat /etc/selinux/config
...
SELINUX=disabled //关闭selinux,下次开机生效
...
5. 其他工具
lspci:显示系统中所有PCI总线设备或连接到该总线上的所有设备的工具
//查看当前主机的所有网卡(包括已经驱动了和没有驱动)
[root@misshou ~]# lspci |grep -i eth
00:03.0 Ethernet controller: Red Hat, Inc Virtio network device
//查看物理连接状态(网线是否ok)
[root@misshou ~]# ethtool eth0
Settings for eth0:
Link detected: yes
[root@node1 ~]# mii-tool eth0
eth0: negotiated 100baseTx-FD, link ok
总结:
网络配置:静态 IP
主机名配置:完全规范主机名 server server.heima.cc
IP 地址和主机名一一绑定写到 host 文件中
关闭防火墙和 selinux
1. 数据单元是网络信息传输的基本单位。一般网络连接不允许传送任意大小的数据包,而是采用分组技术将一个数据分成若干个很小的数据包,并给每个小数据包加 上一些关于此数据包的属性信息. ↩2. 包 (Packet) 是 TCP/IP 协议通信传输中的数据单位,一般也称 “ 数据包 ” 。 ↩3. 帧是数据链路层的传输单元。它将上层传入的数据添加一个头部和尾部,组成了帧 . ↩