综合练习--The Eighth Week

1、简述osi七层模型和TCP/IP五层模型
在这里插入图片描述
1、物理层
物理层(Physical Layer)在局部局域网上传送数据帧(Data Frame),它负责管理电脑通信设备和网络媒体之间的互通。包括了针脚、电压、线缆规范、集线器、中继器、网卡、主机接口卡等
2、数据链路层
数据链路层(Data Link Layer)负责网络寻址、错误侦测和改错。当表头和表尾被加至数据包时,会形成信息框(Data Frame)。数据链表头(DLH)是包含了物理地址和错误侦测及改错的方法。数据链表尾(DLT)是一串指示数据包末端的字符串。例如以太网、无线局域网(Wi-Fi)和通用分组无线服务(GPRS)等。分为两个子层:逻辑链路控制(logical link control,LLC)子层和介质访问控制(Media access control,MAC)子层
3、网络层
网络层(Network Layer)决定数据的路径选择和转寄,将网络表头(NH)加至数据包,以形成报文。网络表头包含了网络数据。例如:互联网协议(IP)等。
4、传输层
传输层(Transport Layer)把传输表头(TH)加至数据以形成数据包。传输表头包含了所使用的协议等发送信息。例如:传输控制协议(TCP)等。
5、会话层
会话层(Session Layer)负责在数据传输中设置和维护电脑网络中两台电脑之间的通信连接。
6、表示层
主条目:表示层(Presentation Layer)把数据转换为能与接收者的系统格式兼容并适合传输的格式
7、应用层
应用层(Application Layer)提供为应用软件而设的接口,以设置与另一应用软件之间的通信。例如: HTTP、HTTPS、FTP、TELNET、SSH、SMTP、POP3、MySQL等

用户数据包封装和解封装
发送方:从应用层到物理层封装
接收方:从物理层到应用层解封装

这个博主讲述的更详细:https://blog.csdn.net/mestryas/article/details/81629218
2、总结描述TCP三次握手四次挥手
TCP三次握手,客户端和服务端的状态变化

1、最初两端的TCP都处在CLOSED(关闭)状态。
B的TCP服务器进程创建传输控制块TCB,服务器进程进入LISTEN(收听)状态,等待客户的连接请求。
2、A的TCP客户进程创建传输控制块TCB,向B发出连接请求报文段。这时,首部中同步位SYN=1,初始序号seq=x。SYN报文段不携带数据,但要消耗一个序号。TCP客户进程进入SYN-SENT(同步已发送)状态。
3、B收到连接请求报文段,如同意建立连接,则向A发送确认。确认报文段中,SYN和ACK都为1,确认号ack=x+1,并选择自己的初始序号seq=y。此报文段同样不携带数据,但要消耗一个序号。TCP服务器进程进入SYN-RCVD(同步接收)状态。
4、TCP客户进程收到B的确认后,向B发出确认。确认报文段的ACK=1,确认号ack=y+1,自己的seq=x+1。ACK报文段可携带数据,不携带数据则不消耗序号。TCP连接已建立,A进入ESTABLISHED(已连接)状态。
5、B收到A的确认,也进入ESTABLISHED状态。
在这里插入图片描述
四次握手

1、开始时,A和B都处在ESTABLISHED状态。
2、A的应用进程向TCP发出连接释放报文段,停止发送数据,关闭TCP连接。A把报文段首部中FIN置为1,序号seq=u,u是已传送的数据的最后一个字节序号加1。A进入FIN-WAIT-1(终止等待1)状态,等待B的确认。FIN报文段即使不携带数据,也要消耗一个序号。
3、B收到连接释放报文段向A发出确认,确认号ack=u+1,B自己的序号是v,v是已传送过的数据的最后一个字节加1。B进入CLOSE-WAIT(关闭等待)状态。TCP服务器进程通知高层应用进程,从A到B的连接被释放。TCP进入半关闭(half-close)状态。
4、A收到B的确认,进入FIN-WAIT-2(终止等待2)状态,等待B发出连接释放报文段。
5、B应用进程通知TCP释放连接,报文段首部FIN=1,序号为w(半关闭状态时B可能又发送了一些数据),B重复上次发送的确认号ack=u+1。B进入LAST-ACK(最后确认)状态,等待A的确认。
6、A收到B的连接释放报文段,向B发出确认。确认报文段中ACK=1,确认号ack=w+1,A自己的序号seq=u+1(发送的FIN报文段使用一个序号)。A进入TIME-WAIT(时间等待)状态。
7、经过时间等待计时器(TIME-WAIT timer)设置的时间2MSL后,A进入CLOSED状态。
最长报文段寿命:Maximum Segment Lifetime,MSL,TCP允许根据不同情况调整此值,RFC 793建议时间2分钟。
8、B收到A的确认,进入CLOSED状态,撤销传输控制块TCB,TCP连接释放成功。

在这里插入图片描述
3、描述TCP和UDP区别

TCP特性 UDP特性
工作在传输层 工作在传输层
面向连接协议 非面向连接协议
全双工协议
半关闭
错误检查 有限的错误检查
将数据打包成段,排序
确认机制 提供不可靠的网络访问
数据恢复,重传 无数据恢复特性
流量控制,滑动窗口
拥塞控制,慢启动和拥塞避免算法

4、总结ip分类以及每个分类可以分配的IP数量
0 0000000 - 0 1111111.X.Y.Z : 0-127.X.Y.Z
网络ID位是最高8位,主机ID是24位低位
网络数:126=2^7(可变是的网络ID位数)-2
每个网络中的主机数:2^24-2=16777214
默认子网掩码:255.0.0.0
私网地址:10.0.0.0
范例:114.114.114.114,8.8.8.8,1.1.1.1,58.87.87.99,119.29.29.29
B类:
10 000000 - 10 111111.X.Y.Z:128-191.X.Y.Z
网络ID位是最高16位,主机ID是16位低位
网络数:2^14=16384
每个网络中的主机数:2^16-2=65534
默认子网掩码:255.255.0.0
私网地址:172.16.0.0-172.31.0.0
范例:180.76.76.76,172.16.0.1
C类:
110 0 0000 - 110 1 1111.X.Y.Z: 192-223.X.Y.Z
网络ID位是最高24位,主机ID是8位低位
网络数:2^21=2097152
每个网络中的主机数:2^8-2=254
默认子网掩码:255.255.255.0
私网地址:192.168.0.0-192.168.255.0
范例: 223.6.6.6
D类:组(多)播,1110 0000 - 1110 1111.X.Y.Z: 224-239.X.Y.Z
E类:保留未使用,240-255
5、总结IP配置方法
方式一:使用ifconfig命令,重启网卡后失效

[root@centos8 ~ ]#rpm -qf `which ifconfig`
net-tools-2.0-0.51.20160912git.el8.x86_64
[root@centos8 ~]# ifconfig eth0 192.168.20.129/24
[root@centos8 ~]# ifconfig 
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.20.129  netmask 255.255.255.0  broadcast 192.168.20.255
        inet6 fe80::b65f:bc0e:cad3:90fd  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:ea:9f:2d  txqueuelen 1000  (Ethernet)
        RX packets 14238  bytes 19111787 (18.2 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 2734  bytes 287717 (280.9 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

方式二: 编辑/etc/sysconfig/network-scripts/ifcfg-eth0配置文件,永久有效,配置后需重启network

[root@centos8 ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0 
[root@centos8 ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0 
NAME=eth0
DEVICE=eth0
IPADDR=192.168.20.130
NETMASEK=255.255.255.0
GATEWAY=192.168.20.2
BOOTPROTO=static
ONBOOT=yes
TYPE=Ethernet
[root@Centos8 ~]# systemctl restart network

方式三:使用ip命令,重启网卡后失效

[root@Centos7 ~]# rpm -qf `which ip`
iproute-4.11.0-25.el7_7.2.x86_64
[root@centos8 ~]# ip addr add 192.168.20.135/24 dev eth0
[root@centos8 ~]# ip addr del 192.168.20.130/24 dev eth0

方式四:使用nmtui进入图形化管理界面,配置后重启网卡生效

[root@centos8 ~]# nmtui
[root@centos8 ~]# nmcli connection reload
[root@centos8 ~]# nmcli connection eth0 up


在这里插入图片描述
方式五:
使用nmcli con add命令创建,该命令会生成一个配置文件ifcfg-static

[root@centos8 ~]# nmcli con add con-name static ifname eth0 type Ethernet ipv4.method manual ipv4.addresses 192.168.20.135/24 ipv4.gateway 192.168.20.2

总结:需网卡配置永久生效还需写入到配置文件。

猜你喜欢

转载自blog.csdn.net/weixin_50904580/article/details/111056360
今日推荐