linux基础-TCP/IP协议篇
一.网络TCP/IP层次模型
1.网络层次模型概念介绍:TCP/IP协议就是用于简化OSI层次,以及相关的标准。传输控制协议(tcp/ip)族是相关国防部(DoD)所创建的,主要用来确保数据的完整性及在毁灭性战争中维持通信
是由一组不同功能的协议组合在一起构成的协议族,利用一组协议完成OSI所实现的功能,不单单是指TCP.IP这两个协议。
2.网络层析模型作用说明:
OSI七层模型简化四层DoD模型,应用层、表示层、会话层统称为应用层,传输层称为主机到主机层,网络层即为因特网层,数据链路层和网络层统称为网络接入层。
3.网络层次模型组成部分如图:
每一层都包含了对应的协议规则,这里说明下ICMP协议,即为平时如果我们检查主机是否在线,通常使用ping 192.168.1.111,这里就用到了ICMP协议,如果ping不通也可能是ICMP协议关闭引起的哦!
4.网络层次模型琢层说明
(1)首先应用层:
应用层包含了以上诸多协议规则,包括一些对应的端口,其中除了TFTP是UDP协议之外,其他全部都为TCP协议。
(2)主机到主机层:
主机到主机层只包含了两个TCP和UDP这两个网络协议
(3)因特网层/网络接入层:
因特网层负责将分组报文从源端发送到目的端,为网络中的设备提供逻辑地址
二.网络TCP/IP模型精讲
1.网络重要协议说明:
TCP(传输控制协议):属于面向连接的网络协议,其可靠性相对UDP来说比较高、流控、使用TCP应用,例如WEB浏览器;电子邮件;文件传输程序。
UDP(用户报文协议):属于无连接的网络协议,不可靠传输,尽力而为,尽力传递,使用的UDP应用,例如域名系统(DNS),视频流,IP语音程序等。
2.网络协议报文结构:
源端口随机分配,目标端口使用知名端口,在linux系统上的/proc/sys/net/ipv4/ip_local_port_rang位置存放的是本地端口的取值范围。
由于TCP协议头部使用16位来保存端口号,所以端口的个数最多为65536个,2~16=65536,0号端口不会被tcp和udp协议使用。tcp和udp协议端口号范围是1-65535.
控制字段说明(控制字段信息默认为0,控制字段功能不起作用;控制字段信息置为1,表示相应控制字段功能开启):
ack:表示确认控制字段,实现数据可靠连接
syn:表示请求建立连接字段
fin:表示请求断开连接字段
sep*num:此字段表示数据在发送过程中,需要把切分的数据排上序号依次发送给接收方,这样避免接收到数据在打包后的损坏问题。
ack*num;此字段表示在数据发送中,排序号的数据发送给接收号,接收号按序号给出一个接收相应,避免序号紊乱问题。
应用客户端使用的源端口号一般为系统中未使用的且大于1024的,目的端口号为服务端应用服务的进程,如telnet为23.
3.网络连接的建立过程(TCP/IP)三次握手:
简要概括如下:一握手:请求建立连接(syn)
二握手:连接确认再请求(ack syn)
三握手:最后确认,即建立(ack)
4.网络连接建立过程(四次挥手):
简要概括如下:
一挥手:请求连接断开(fin)
二挥手:断开请求要确认(ack)
三挥手:思考之后要断开(fin,ack)
四挥手:最后确认,即断开(ack)
5.网络状态转换过程:
客户端独有的:SYN_SENT 、FIN_WAIT1 、FIN_WAIT2 、CLOSING 、TIME_WAIT 。
服务端独有的:LISTEN、SYN_RCVD 、CLOSE_WAIT、LAST_ACK 。
共有的:CLOSED、ESTABLISHED
三.网络TCP/CP涉及的原理
1.ARR协议原理:
将ipv4地址解析为MAC地址
维护映射的缓存
原理说明:当主机1.1想要与其他主机通信发送消息时,需要向其他主机发送大量的广播信息用于查找其他主机,同理其他主机想要发送消息也一样,因此ARP协议就诞生了,当第一次找到其他主机时就会维护一个映射的缓存,下次在连接此主机就无需再发送广播信息来查找主机了。因此ARP协议就是为了解决主机间相互连接时的广播风暴问题。
2.DNS协议原理:
DNS是什么?(Domain Name System)
DNS称为域名系统,在网站运行中起到了至关重要的作用,只要作用是负责把网站域名解析为对应的IP地址。
说明:域名的层次级别:
第一个级别:称为 根域名服务器 .(全球13个)
第二个级别:称为 顶级域名服务器(一级域名服务器).com .cn .gov
第三个级别:称为 二级域名服务器(授权DNS服务器).baidu.com .jd.com
第四个级别:称为 虚拟主机信息 www.baidu.com www.jd.com
DNS解析相关命令
dig @8.8.8.8 www.xxx.com +trace
nslookup www.xxx.com
host www.xxx.com
ping www.xxx.com
linux基础-TCP/IP协议篇的更多相关文章
- 网络基础tcp/ip协议一
计算机网络: 硬件方面:通过线缆将网络设备和计算机连接起来 软件方面:操作系统,应用软件,应用程序通过通信线路互连 实现资源共享,信息传递 计算机网络的功能: 数据通信 资源共享 增加可靠性 提高系统 ...
- Linux基础:网络协议篇
01.网络协议 1. 操作系统基础 操作系统(operating System 简称OS)是管理和控制计算机硬件与软件自愿的计算机程序,是直接运行在"裸机"上的基本的系统软件,任何 ...
- 网络基础tcp/ip协议四
网络层的功能: 定义了基于ip协议的逻辑地址. 链接不同的媒介类型. 选择数据通过网络的最佳路劲. 数据包格式: 优先级与服务类型(8)位:优先级与服务类型 标识符,标志,段偏移量:这几个字用来对数据 ...
- 网络基础tcp/ip协议二
物理层解析: 物理层是TCP/IP模型的最低层,物理层为数据提供数据传输可靠通路. 物理层关心的介质: 信号 接口 传输介质 信号的分类:(信号是信息传递的媒介.) 模拟信号:连续变化的物理量 数字信 ...
- 网络基础tcp/ip协议五
传输层的作用: ip层提供点到点的链接. 传输层提供端到端的链接. 传输层的协议: TCP: 传输控制协议可靠的,面向链接的协议,传输效率低. UDP: 用户数据报协议,不可靠,无连接的服务,传输效率 ...
- 网络基础tcp/ip协议三
数据链路层:(位于网络层与物理层之间) 数据链路层的功能: 数据链路的建立,维护. 帧包装,帧传输,帧同步. 帧的差错恢复. 流量的控制. 以太网:(工作在数据链路层) CSMA/CD(带冲突检测的载 ...
- java 网络编程基础 TCP/IP协议:服务端ServerSocket;客户端Socket; 采用多线程方式处理网络请求
1.Java中客户端和服务器端通信的简单实例 Java中能接收其他通信实体连接请求的类是ServerSocket,ServerSocket对象用于监听来自客户端的Socket连接,如果没有连接,它将一 ...
- 【Linux网络基础】TCP/IP协议簇的详细介绍(三次握手四次断开,11种状态)
一.TCP/IP协议簇(DoD参考模型) 用于简化OSI层次,以及相关的标准. 传输控制协议(tcp/ip)簇是相关国防部DoD所创建的,主要用来确保数据的完整性以及在毁灭性战争中维持通信 是由一组不 ...
- 【Linux网络基础】网络拓扑、OSI层次模型、TCP/IP协议簇
一.前言 一个运维有时也要和网络打交道,所以具备最基本的网络知识,对一个运维人员来说是必要的.但,对于我们的工作来说这些并不是重点,因此,我不可能从最基础的网络知识开始讲起.本节内容更多是从一个梳理和 ...
随机推荐
- Python MySSH 实现剧本执行器
通过封装Paramiko这个SSH模块,我们可以实现远程批量管理Linux主机,在上一篇文章中我们封装过一个MySSH类,这个类可以执行命令上传下载文件等,我们在这个类的基础上,实现一个简单的任务执行 ...
- 关于使用idea工具debug时,断点颜色由红色变成灰色
在使用断点调试的时候,发现断点由原来的红色变成灰色的,后来发现是由于错误操作将Debug断点t调试禁用了 ,只需要点击禁用按钮取消就可以了
- oracle 使用union提示ORA-00907:缺少右括号
在使用union的时候提示:ORA-00907:缺少右括号 此原因是因为在union的左边和右边都有order by,因此需要去掉一边的order by,保留一个即可. 例如: select * fr ...
- Git项目迁移(把当前git项目迁移到新的git地址)
使用 git clone --bare 命令clone当前git git clone --bare http://gitlab.xxx/demo.git 推到新的git地址 cd demo.git g ...
- vue 快速入门 系列 —— 使用 vue-cli 3 搭建一个项目(下)
其他章节请看: vue 快速入门 系列 使用 vue-cli 3 搭建一个项目(下) 上篇 我们已经成功引入 element-ui.axios.mock.iconfont.nprogress,本篇继续 ...
- 大爽Python入门教程 0-4 安装Pycharm
大爽Python入门公开课教案 点击查看教程总目录 安装重量级IDE--Pycharm 一 下载 下面步骤1,2中网络卡顿的朋友, 请直接前往步骤3来下载. 使用搜索引擎搜索Pycharm, 打开搜索 ...
- Python-Unittest多线程执行用例
前言 假设执行一条脚本(.py)用例一分钟,那么100个脚本需要100分钟,当你的用例达到一千条时需要1000分钟,也就是16个多小时... 那么如何并行运行多个.py的脚本,节省时间呢?这就用到多线 ...
- Alpine容器安装运行ssh
写在前面 本文介绍了在Alpine容器(docker)上安装运行ssh并保证外界(宿主机)能通过ssh登录的方法,给出了相应的命令.在下在探索过程中借鉴了许多前人的经验,在此先行谢过,所有参考内容都会 ...
- react之redux状态管理
1.传统MVC框架的缺陷 模型(model)-视图(view)-控制器(controller)的缩写 V即View视图:用户看到并与之交互的界面. M即Model模型是管理数据:很多业务逻辑都在模型中 ...
- [hdu6989]Didn't I Say to Make My Abilities Average in the Next Life?!
显然问题即求$\frac{\sum_{x\le l\le r\le y}(\max_{l\le i\le r}a_{i}+\min_{l\le i\le r}a_{i})}{(y-x+2)(y-x+1 ...