谈谈网络分层和IP
概述
在计算机网络这门课中,往往是将各层协议拆开一章一章的讲,每层协议是干嘛的,都各种怎么工作的。但如果有人问,这些协议之间怎么协调工作,有什么关系,往往处于懵逼状态。
网络分层
网络为什么分层,其实理解很简单,复杂的东西都要分层。就像写代码,有Controller层,service层,dao层等,如果这个代码很复杂,都写在一个类里里,不利于你后期维护(可能过两天你自己都看不懂了),和同事之间的交流沟通也不方便。所以复杂的程序都要分层,这是基本的程序设计要求。
这是一次用户发起的请求,浏览器用http协议打包用户的请求,然后传给下一层,调用下一层函数,这个函数会在这个网络包里加上一个TCP头,记录下源端口号,目的端口号,然后在调用下一层的函数,这个函数会加一个IP的头,记录源IP地址和目标IP的地址,然后在调用下一次函数,这个函数又加了一个本机器的MAC地址和目标MAC地址。这个数据包完整后,就可以从网口发出去。
网卡检测到这个网络包的目的地址是指向自己的,把这个数据包拿进来调用一段函数来处理这个网络包,把属于这层的东西剥离出去,然后调用另一层的一个函数(process_layer3())来处理这个网络包。这一层检测一下,目标IP是不是对上自己的IP,如果IP对不上,就转发出去,若是对上IP,取下属于这层的IP头,在调用下一层的函数来处理。那是调用TCP函数还是UDP的函数处理哪,这个就得看协议字段,我这次请求是TCP的,就调用TCP的函数取下TCP头,然后查看这是一个发起,还是应答,或者是一个正常数据包,如果是发起或者应答,还需要发送一个回复包,若是一个正常数据包,根据端口号就直接交给应用去处理,然后浏览器解析html,用户现实界面。
网络上跑的包,都是完整的,可以有下层没上层,绝对不可能有上层没下层。这有点类似于俄罗斯套娃,一层连着一层,一开始是个很小的套娃,套一层又套一层,套完后就是一个完整的套娃。网络世界中也是一样的,http层数据包,在套上TCP层,在套上IP层,又套上MAC层,所有机制都得运行一遍才能成功从网口发出去。
IP
不管学没学过计算机,一定都会听到的词===>IP。有没有想过,MAC地址就可以标识电脑了,还要IP干嘛,我刚开始也模糊,后面才逐渐有点头绪(但现在也不知道理解是否全对,毕竟计算机网络小白)。MAC地址与设备是一 一对应在局域网内是唯一的,如果在局域网内,MAC地址直接通信是没有问题的,每次有消息的时候,各个主机都接收一下,对照下是不是自己的MAC地址,如果不是,就直接丢弃,对上就接收并处理。但是每次有消息都得接收和处理有点费事,于是出现了交换机,交换机记录所有与之连接的MAC地址并与端口一一对应,现在A主机发消息给B主机并带上B主机的MAC地址,现在先到交换机这里,交换机查下记录的MAC对照表,哦,原来你要找B主机,就按照这个端口发给B主机。为什么会有IP哪,以太网MAC地址就可以通信了,但后来有了互联网,兼容以前的模式才有了IP + MAC的通信模式,长春这边的局域网有台A主机要与北京的局域网一台B主机通信。长春的交换机记录了A主机的MAC地址,可能还记录了北京交换机的MAC地址,北京交换机记录了要通信的B主机MAC地址。现在A给交换机发消息,我要找B主机,很遗憾,交换机找不到B主机,因为不是一个局域网内,交换机没记录这个MAC地址,没法通信。
MAC地址是硬件提供商写在网卡中的,MAC地址是唯一,但没办法表示我在互联网的位置,除非维护一个超级大的MAC地址对应表,那寻址效率必定爆炸,而且获取MAC地址是ARP协议完成的,只用MAC地址通信广播风暴就是很难克服的问题,但IP地址解决了这个问题,IP地址是网络提供商给的,你在哪里整个网络都是知道的(类似于定位功能),找到你这个网络,在这个网络环境找到你的MAC就显得容易得多。但是IP地址不总是唯一的,可能我今天在长春这个网络环境,我下线了,我这个IP就会动态分配给别的设备,明天到了北京,又动态分了一个IP地址,然而我的MAC地址总是固定且唯一的,通过这个我网络IP地址和MAC地址就很容易找到我。
ip addr
查看ip地址,192.168.181.110就是一个IP地址,总共有四个部分,每部分有8位,总共有32位,理论上可以有42.9亿个IP地址,然而这些显然不能满足日益增长的计算机IP需求,因为不够用,所以有了IPV6,也就是我们的 fe80::20c:29ff:feb6:4146/64,这个有128位,有生之年都不可能分配完,据说可以给地球的每粒沙子分配一个IP,就可以想象有多少IP地址了。IP地址是一个网卡在网络世界的通讯地址,也相当于现实世界的门牌号码,所以不能重复,它包括两个标识码(网络ID + 主机ID)。在同一个物理网络上的所有主机都使用同一个网络ID,网络上的主机(路由器,服务器等)有一个主机ID与其对应,早期IP地址为了便于寻址和层次化构造网络,把IP分为5种类型,即A,B,C,D,E类地址。
A类
A类的地址,8位网络地址,和24位的主机地址组成。地址范围 1.0.0.0 -> 126.255.255.255,A类网络有127个,每个网络能容纳16777214的主机。
B类
B类的地址,16位网络地址,和16位的主机地址组成,地址范围128.0.0.0 -> 191.255.255.255,B类网络有16382个,每个网络可以有六万多主机
C类
C类的地址,24位的网络地址,和8位的主机号,地址范围 192.0.0.0 -> 223.255.255.0,C类网络有209万个,每个网络只能有可怜的254个主机
D类
D类的地址,从图中就可以看到,不分网络地址和主机地址,被称为广播地址,供特殊协议向选定节点发送消息时用,第一个字节是固定的1110,地址范围 224.0.0.0 ->239.255.255.255
E类
E类的地址,保留将来使用。240.0.0.0 -> 255.255.255.254
特殊地址
大家在使用本地测试访问经常用到的 127.0.0.1 表示主机本身,是一个回环测试地址。
在阿里云服务器使用监听地址 0.0.0.0 会有这样的设置,他在IPV4表示的是无效的目标地址,但在服务器端上它表示本机上所有的IPV4网段都能访问该服务
在A,B,C类地址中,各自保留一个区域作为私有地址
- A类:10.0.0.0 -> 10.255.255.255
- B类:172.16.0.0 -> 172.31.255.255
- C类:192.168.0.0 -> 192.168.255.255
CIDR
在一个网吧用C类的IP地址,恐怕地址都不够,但是若是用B类地址,又是一种浪费。于是出现一个折中的办法,那就是无类域间路由,简称CIDR。给某个网络分配3个C类地址,然后适当的方法分配地址,使得3个地址能够聚合成一个地址。如果没有CIDR技术,ISP(地址网络提供商)的路由表就会有三条路由条目,但如果有了CIDR技术,就可以把这三个网段 198.168.1.0 198.168.2.0 198.168.3.0 汇聚成一条路由 198.168.0.0/16,这样ISP的路由表就只记录了一条198.168.0.0/16这一条路由,减少了路由表的条目,但若是ISP连接了一个172.168.1.0的网段,这些网络路由就没办法汇聚。CIRD节省了存储空间加快了查询速度。所以,现在都是用CIDR表示,为此引入子网掩码的概念,就是说网络位的个数可以任意指定,同时也兼容早期IP划分的方法。它将某个IP地址划分成网络地址和主机地址两部分,子网掩码是一个32位地址,用于屏蔽IP地址的一部分,它不能单独存在,必须结合IP地址一起使用,198.168.0.0/16 这个16就是指网络位有多少,在二进制格式中的网络位全为1,然后将二进制格式的子网掩码和二进制的IP地址进行 ‘与’ 运算,就可以得出该IP的网络位。
IP地址:192.168.181.111 二进制:11000000 10101000 10110101 01101110
子网掩码:255.255.255.0 二进制:11111111 11111111 11111111 00000000
运算: & 11000000 10101000 10110101 00000000
结果:192.168.181.0
这就是网络号了
总结
简单的总结合和回忆了对ip的理解,虽然是基础知识,但是lz真的是计算机网络小白,也不知道是否理解准确,有大神有这方面的知识储备,是否可留言讲解下IP。
参考:https://www.jianshu.com/p/e7989a7a0e96
谈谈网络分层和IP的更多相关文章
- 第12章 网络基础(1)_网络分层和TCP/IP协议族
1. 协议的概念 (1)计算机网络中实现通信必须有一些约定.如对速率.传输代码.代码结构.传输控制步骤和出错控制等约定,这些约定即被称为通信协议 (2)在两个节点之间要成功地进行通信,两个节点之间必须 ...
- HTTP协议复习三--TCP/IP的网络分层模型和OSI 网络分层模型
TCP/IP网络分层模型 第一层叫“链接层”(link layer),负责在以太网.WiFi这样的底层网络上发送原始数据包,工 作在网卡这个层次,使用MAC地址来标记网络上的设备,所以有时候也叫MAC ...
- JAVA基础知识之网络编程——-TCP/IP协议,socket通信,服务器客户端通信demo
OSI模型分层 OSI模型是指国际标准化组织(ISO)提出的开放系统互连参考模型(Open System Interconnection Reference Model,OSI/RM),它将网络分为七 ...
- UNIX网络编程——TCP/IP简介
一.ISO/OSI参考模型 OSI(open system interconnection)开放系统互联模型是由ISO(International Organization for Standardi ...
- 网络知识--OSI七层网络与TCP/IP五层网络架构及二层/三层网络
作为一个合格的运维人员,一定要熟悉掌握OSI七层网络和TCP/IP五层网络结构知识. 废话不多说!下面就逐一展开对这两个网络架构知识的说明:一.OSI七层网络协议OSI是Open System Int ...
- 网络分层和Http协议原理
网络分层: 应用层 传输层 网络层 数据链路层 物理层 物理层: 比特流在节点之间的传输,是计算机连接起来的物理手段. 数据链路层: 控制网络层和物理层之间的通信,功能是在不可靠的物理线路上进行数据可 ...
- 网络知识梳理--OSI七层网络与TCP/IP五层网络架构及二层/三层网络(转)
reference:https://www.cnblogs.com/kevingrace/p/5909719.html https://www.cnblogs.com/awkflf11/p/9190 ...
- Java网络编程のTCP/IP
TCP/IP参考模型和TCP/IP协议 与OSI参考模型相似,TCP/IP参考模型汲取了网络分层的思想,而且对网络的层次做了简化,并在网络各层都提供了完善的协议,这些协议构成了TCP/IP协议集,简称 ...
- 加深理解HTTP请求---网络基础TCP/IP
为了了解HTTP,必须的了解TCP/IP协议族. 通常使用的网络实在TCP/IP协议族的基础上运作的.而HTTP就属于他的一个子集. 1.TCP/IP 协议族 计算机与网络设备要相互通信,双方就必须基 ...
随机推荐
- 学会分析YUV数据
做视频采集与处理,自然少不了要学会分析YUV数据.因为从采集的角度来说,一般的视频采集芯片输出的码流一般都是YUV数据流的形式,而从视频处理(例如H.264.MPEG视频编解码)的角度来说,也是在原始 ...
- Jmeter(二十七)_Beanshell保存响应内容到本地
利用Jmeter-BeanShell PostProcessor可以提取响应结果并保存到本地文件,这种操作在jmeter做爬虫时非常有用,可以帮助你迅速的获取想要的内容到本地文件! 1:在本地新建一个 ...
- mongodb的安装使用,window和centos环境
官网:https://www.mongodb.org/downloads 版本:最终稳定版 (mongodb-win32-x86_64-2008plus-ssl-3.2.6-signed.msi 绿色 ...
- 页面标准文档流、浮动层、float属性(转)
CSS float 浮动属性介绍 float属性:定义元素朝哪个方向浮动. 1.页面标准文档流.浮动层.float属性 1.1 文档流 HTML页面的标准文档流(默认布局)是:从上到下,从左到右,遇块 ...
- CRM客户关系管理系统(九)
第九章.filter_horizontal优化和kingadmin删除功能 9.1.filter_horizontal优化 (1)添加Choose ALL 和Remove ALL table_obj_ ...
- numpy用法归纳
1.生成数组 import numpy as np 把python列表转换为数组 >>> np.array([1, 2, 3]) array([1, 2, 3]) 把python的r ...
- Version 1.6.0 of the JVM is not suitable for the this product.Version:1.8 or greater is required
这个问题时在打开eclipse时报的一个错误,报这个问题的意思我们都明白,说的就是当前版本的jdk版本太低,eclipse需要更高版本的jdk. 那就下一个更高版本的jdk就可以啦,这里我要说说我当时 ...
- IM进化论:腾讯也难逃被颠覆掉的命运
在一定程度上,腾讯代表了中国IM领域的过去和未来.但有句俗话,后来推前浪,前浪被拍死在沙滩上,"生死腾讯"也总会变为生和死,因为腾讯很可能会有被颠覆掉的一天.腾讯的IM接口是个庞然 ...
- FutureTask理解
一.概述 FutureTask包装器是一种非常便利的机制,同时实现了Future和Runnable接口. 类图如下: FutureTask是一种可以取消的异步的计算任务.它的计算是通过Callable ...
- 优雅的玩PHP多进程
proc_open (PHP 4 >= 4.3.0, PHP 5, PHP 7) proc_open — 执行一个命令,并且打开用来输入/输出的文件指针. 说明¶ resource proc_o ...