一、OSI参考模型:适用于所有网络,现有模型,后有协议
1、应用层:应用程序、用户接口
2、表示层:编码转换、压缩、解压、加密等
3、会话层:建立、维护、拆除会话
4、传输层规定了应用程序的的接口
协议:TCP、UDP    PDU:数据段
5、网络层:为数据传输选择一条最优路径,采用尽力而为的发送方式
工作设备:路由器    PDU:数据包    逻辑地址:IP地址    
协议:IP、ARP、RARP、ICMP
6、数据链路层:使用MAC地址(48位2进制,前24位厂商,后24位为设备地址)传输数据帧 
工作设备:交换机    协议:ARP、RARP    数据帧格式:
7、物理层:介质和信号(双绞线、光线、同轴电缆和模拟信号、数字信号),物理层关心的是电气特性、规程特性、功能特性、物理特性,从数据链路层接收数据转换为bit流,为数据传输提供安全的通信通道
【1】交换机功能:
自学习:学习源MAC以及进入的接口
广播:
转发:
过滤:
更新:
【2】数据帧格式:
【3】集线器(hub)工作原理:
            收到一个bit时,将该bit向其他所有接口传输出去,是一个广播域网,且没有冲突检测
【4】路由器:
            根据路由表转发数据,分为直连路由、非直连路由
            直连路由:为接口配置IP地址并保证UP状态
            非直连路由:通过静态指定或动态学习
【5】IP协议: 
版本:4位,标识IP地址的版本,常用的是IPv4和IPv6
首部长度:4位,可变长度,根据可选项变化
优先级与服务类型:8位,提供第三层的服务质量
总长度:16位,IP包头总长度
标识符:16位,为分段数据打上标记,方便到目标地址重新组装
标志:3位,第一位没有设置,第二位是DF,决定是否分片,0代表部分片,1代表分片;第三位是MF:代表更多的片,只有数据的最后一片值为0
段偏移量:13位,代表数据片在整个数据中的位置
TTL:8位,生命周期,数据包经过路由器个数,数据包每经过一个路由器,TTL值减一,当TTL值为0时,数据还没有到达目标地址,该数据将被丢弃,一般设置为32或64
协议号:8位,标识上层协议号
首部校验和:16位,验证发送端和接收端数据的完整性
源地址:32的IP地址
目标地址:32的IP地址
可选项:松散路由 严格路由 路由标记 时间戳
填充:把IP包头每行都填充为32位
【6】ARP协议:      
硬件类型
协议类型
硬件地址长度
协议长度
Opcode
发送方MAC地址
发送方IP地址
目的MAC地址
目的IP地址
【7】RARP协议: 逆地址解析协议 RARP 使只知道自己硬件地址的主机能够知道其IP地址
【8】ICMP协议:ICMP报文作为IP层数据报的数据,加上数据报的首部,组成 IP 数据报发送出去   
ICMP报文的前4个字节是统一的格式,共有三个字段:即类型,代码和检验和.接着的4个字节的内容与ICMP的类型有关
【9】TCP协议:      
源端口
目的端口
序列号
指定ack号
包头头长度
Flags(标志位):
URG:紧急指针有效位,标记紧急数据
ACK:确认序列号有效位
PSH:通知接收端把数据交给进程,不要在缓冲区中停留
RST:请求重新建立三次握手
SYN:请求建立三次握手
FIN:请求断开连接
窗口大小:
适当的窗口大小
TCP窗口大小比例系数
校验和 
TCP流量控制机制:
以消除发送方使接收方缓存溢出的可能性,是一个速度匹配服务,即发送发速率与接收方应用程序的读取速率相匹配。
发送方维护一个接收窗口,该接收窗口给发送方指示了接收方还有多少缓存空间剩余
发送方:LastSent-LastAcked≤rwnd(接收窗口)
接收方:LastRcvd-LastRead≤RcvBuffer 
TCP拥塞控制:
 在发送方新增一个额外变量 cwnd(拥塞窗口),LastSent-LastAcked≤min{ cwnd, rwnd}
TCP拥塞控制算法:
    慢启动
    拥塞避免
    快速恢复
总结:线性增,乘性减
TCP差错控制:
三个简单工具:
    检验和
    确认
    超时
TCP时间计时器:
重传计时器
坚持计时器: 解决零窗口大小通知可能导致的死锁问题,发送端建立该计时器
保活计时器: 为了防止两个TCP连接出现长时间的空闲。当客户端与服务器端建立TCP连接后,很长时间内客户端都没有向服务器端发送数据,服务端建立保活计时器。
时间等待计时器: 连接终止期间使用,先断开连接的一方建立
【10】UDP协议:     
 
二、TCP/IP网络协议模型:只适用于TCP/IP网络,先有协议,后有模型
    1、应用层
    2、传输层
    3、网络层
    4、数据链路层
    5、物理层
 
 

Linux学习笔记05之网络基础知识的更多相关文章

  1. Linux 学习笔记之超详细基础linux命令(the end)

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 14---------------- ...

  2. Linux 学习笔记之超详细基础linux命令 Part 14

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 13---------------- ...

  3. Linux 学习笔记之超详细基础linux命令 Part 13

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 12---------------- ...

  4. Linux 学习笔记之超详细基础linux命令 Part 10

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 9----------------- ...

  5. Linux 学习笔记之超详细基础linux命令 Part 7

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 6----------------- ...

  6. Linux 学习笔记之超详细基础linux命令 Part 12

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 11---------------- ...

  7. Linux 学习笔记之超详细基础linux命令 Part 11

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 10---------------- ...

  8. Linux 学习笔记之超详细基础linux命令 Part 9

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 8----------------- ...

  9. Linux 学习笔记之超详细基础linux命令 Part 8

    Linux学习笔记之超详细基础linux命令 by:授客 QQ:1033553122 ---------------------------------接Part 7----------------- ...

随机推荐

  1. HBase 学习之路(六)——HBase Java API 的基本使用

    一.简述 截至到目前(2019.04),HBase 有两个主要的版本,分别是1.x 和 2.x ,两个版本的Java API有所不同,1.x 中某些方法在2.x中被标识为@deprecated过时.所 ...

  2. 【Netty4】深入学习Netty

    Netty is an asynchronous event-driven network application framework  for rapid development of mainta ...

  3. RocketMQ(7)---RocketMQ顺序消费

    RocketMQ顺序消费 如果要保证顺序消费,那么他的核心点就是:生产者有序存储.消费者有序消费. 一.概念 1.什么是无序消息 无序消息 无序消息也指普通的消息,Producer 只管发送消息,Co ...

  4. VirtualBox中安装CentOS使得在ssh和外网都能正常链接

    一.网卡模式选择 网卡1:Host-only 用于主宿机互访,这是主宿机通过192.168.56.X这一网络通信,主机是否能上网不影响双方通信 网卡2:NAT 宿机用这一网卡通过主机上网 二.具体配置 ...

  5. 终于有人说清楚了--XGBoost算法

    1. 什么是XGBoost XGBoost是陈天奇等人开发的一个开源机器学习项目,高效地实现了GBDT算法并进行了算法和工程上的许多改进,被广泛应用在Kaggle竞赛及其他许多机器学习竞赛中并取得了不 ...

  6. HDU 2298:Toxophily(推公式)

    http://acm.hdu.edu.cn/showproblem.php?pid=2298 题意:给出一个x,y,v,问从(0,0)以v为初速度射箭,能否射到(x,y)这个点,如果能,输出最小的射出 ...

  7. (转)Java 8 中的 Streams API 详解

    为什么需要 Stream Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念.它也不同于 StAX 对 ...

  8. c++稍微复杂桶排序(未完待续~)

    由于上次的桶排序占用空间太多,这次又有了一个新的办法 直接上代码: #include <bits/stdc++.h> using namespace std; int n; void bu ...

  9. Windows下通过VNC远程访问Linux服务器,并实现可视化

    前言 最近因部门需要,老大想让我在公司Linux服务器上弄个Oracle,以用作部门测试环境的数据库服务器,经过一番折腾后,成功完成了任务.因公司Linux服务器是无图形界面的,本人接触Linux不多 ...

  10. 使用wincc C脚本查找窗口句柄的方法

    关于窗口句柄的用法,网上可以搜到很多相关的文章,本文以windows API接口函数为例,简单介绍一下基本使用,主要包括找到此窗体,在找到的窗体写入数据,对窗体进行关闭,最大化,最小化的操作: 1.利 ...