CPU:网卡老哥,你到底怎么工作的?
阿Q造访
我是一个网卡,居住在一个机箱内的主板上,负责整台计算机的网络通信,要是没有我,这里就成了一个信息孤岛了,那也太无聊了~
上个周末,服务器断电维护了,这是我难得的休息时间,我准备打个盹儿眯一会儿。
这才刚合上眼,CPU一号车间的阿Q跑过来串门了。
“怎么是你小子,听说你背后说了我很多坏话啊!今天怎么想起找我来了”
“网卡老哥,你这都听谁造的谣,我想来拜访你很久了,这不平时工作太忙抽不开身,今天停电了一有空就找你来了嘛!”,阿Q笑着说到。
“你可是大忙人,无事不登三宝殿,说吧,找我什么事儿”
阿Q露出了尴尬而不失礼貌的微笑,“那我就开门见山了,这不年底了吗,咱们厂里最近评优呢,想学点网络知识,特来向你讨教讨教”
“就这啊,好说好说,来里边坐”,我招待阿Q进门坐下。
刚刚落座,阿Q就忍不住提问:“老哥,你们网卡是怎么工作的?听说你可以抓到别的主机通信的数据包?可以给我露一手吗?”
“唉,现在不行了”,我叹了一口气。
“咋了这是?”
我抬头凝望,开始给阿Q讲起了我的故事。
集线器时代
很久很久以前,那时候网络中的各个计算机都是通过一个叫集线器Hub的家伙来相连的,通过集线器,我们大家在物理上构成了一个星型的网络,还给取了个名字:以太网。那时候我们的传输速度能做到10Mbps,在那个年代,已经非常了不起了!。
集线器这家伙,不知道该说他笨,还是该说他懒,他从来不会管数据是谁发给谁,只是一个没有感情的转发机器,工作在物理层,把收到的信号做一个增强处理后就一股脑的发给所有端口。
这样一来,我们在逻辑上就变成了一个总线型网络了。总线属于公共资源,由所有连接在上面的主机共享,有人在传输数据的时候其他人就得等着,不然数据就会发生冲突,全乱套了。
为了让大家都能和平共处,不必为了争抢线路发生不愉快,我们制定了一套规则:CSMA/CD。
每次要发送数据之前,我都得要监听一下线路上是否空闲,如果有别人在传输数据,那我就得等待。至于等待多久,我也不知道,因为这是一个随机值。
等到空闲的时候,我就可以发送数据了。不过一边发送,我还得一边检测是否有冲突发生,因为说不定有别人跟我一样以为现在空闲都在发送数据呢!
所以这就是CSMA/CD——载波侦听多路访问/冲突检测名字的来历了。
但是如果数据的长度太短,我很快就发送完了,结果先头部队还在路上,这之后再遇到冲突那我就发现不了了。为了应对这种情况,我们还得考虑即便是在极端情况下发生冲突,我们还是能够检测到。
我们这个网络能够支持的最远距离是2500米,极端情况下,到达最远端的时候冲突才发生。冲突信号得赶在我发送完最后一个bit之前传回来,这一来一回就是5000米。
线路上的信号跑个来回需要57.6微秒,我们的传输速度是10Mbps,一个来回的时间我就能发送576bit,也就是72个字节,除开8个字节的帧前导符和帧开始符,剩下的以太网帧长度不能低于64个字节,这样就算在最远两端发生的碰撞冲突都能及时传递回去被检测到。
有了这套协议,大家再也不用争抢,可以专心工作了。
“我说为什么非得要至少64字节你才发送,原来还有这段历史呢!那你们具体是怎么收发数据的呢?”,说到这儿,阿Q打断了我。
“那你听我继续给你说”
数据收发过程
我每天的工作就是接收、发送数据包,操作系统把数据交给我以后,我就按照以太网的数据格式,把数据封装成一个个的以太网帧发出去
帧的头部有收件人和发件人的地址,我们叫它MAC地址,这是我们每个网卡的身份证号码,从我们出生那一刻起就确定了。
发件人是我的MAC地址,但收件人地址我不知道啊!操作系统协议栈部门交给我的数据包只有IP地址,我们又不认识这个,我们收发数据帧只用MAC地址。
为了解决这个问题,我们又制定了一套协议:ARP,地址解析协议,来实现这两个地址的转换。在不知道IP对应的MAC地址时候,就发送一个广播,这个广播的发件人地址填我的,然后收件人地址是FF:FF:FF:FF:FF:FF,这是一个特殊的MAC地址,我们约定好了每个人收到广播都要接收而不能丢弃。
这个广播里面填了IP地址,谁收到以后发现跟自己的匹配上就来应答我,这样我就能知道对方的MAC地址了,接下来就能通信了。
当然,为了避免每一次都去询问一遍浪费时间,我会把查询过的记录缓存起来,下次就能直接用啦。
不过这样做也有安全风险,要是有人冒充真正的收件人给我回信,我也没办法分辨,这就叫ARP欺骗。
“唉,等等,你还是给我讲讲你是怎么可以抓到别人的通信数据吧,我对这个更有兴趣。”,阿Q又一次打断了我。
因为集线器这家伙闭着眼睛到处转发,所以不管是谁发的数据,所有人都可以看到。
就因为这样,总线中每天有大量数据在流动,但我通常也不会全部都抓下来交给你们处理,不然你们CPU的人估计要骂死我了。所以我每次拿到一个数据帧,就会检查它的收件人是不是我,如果不是那就直接丢弃了,当然,前面我说的广播消息例外。
我能抓到别人通信数据的秘密就在于:我提供了一种工作模式叫做混杂模式,这种模式下,我就会把总线中我看到的所有数据帧全部都抓下来交给你们CPU去处理,一般都是一些抓包软件才会要求我这么做,但也有一些流氓软件和病毒木马经常让我抓别人的数据包,这样他们就能嗅探网络中的其他主机的通信了。
我并不喜欢这样,因为每次一开启混杂模式,我和你们CPU就忙的要死,主板上的风扇都会疯狂的转起来。
“原来是这样,那你开启混杂模式给我露一手看看呗,可以看到别人的通信数据,这也太刺激了!”,阿Q又又又一次打断了我。
“你别着急,听我继续说嘛,别老是打断我,而且现在停电了,我想露一手也露不了啊?”
“好好好,你继续,继续,我不插嘴了。”
交换机时代
不知道从什么时候开始,就算我开启混杂模式,也抓不到别人的数据包了,因为我发现网络中的数据包只有跟我相关的了。
后来一打听才知道,不只是我一个网卡这样,别的也一样。
原来集线器那家伙退休了,新来了一个叫交换机的大佬取代了他的位置。
这位大佬名不虚传,他不只是简单的把大家连接在一块儿,它还会学习,用一张表把大家的MAC地址和连接的端口号记录下来。每次收到数据后,它只转发给对应的端口,而不会像集线器那样到处转发,我再也看不到别人的通信数据了!
“啊?交换机那家伙可真多事!”,阿Q露出了失望的表情。
这也是件好事啊,交换机大佬不用到处转发数据占用线路,相当于把冲突域进行了隔离,我连接的线路上只有我自己的数据,没有别人的数据,就不会和别的主机传输数据发生冲突了。不仅如此,我们连接的网线也进行了升级换代了,现在我们可以全双工通信,一边收一边发,也不用和交换机发给我的下行数据发生冲突!
隔离冲突域+全双工通信,现在再也不用CSMA/CD,因为不会有冲突发生,可以随心发送数据了,真是爽太多了!我们的传输速度也是日新月异,从10Mbps到100Mbps,再到1000Mbps,越来越快,这在以前想都不敢想。
阿Q点了点头说到:“厉害了,网卡老哥!真是塞翁失马焉知非福”
说完,CPU六号车间的小六出现在了门口,只见他满头大汗的说到:“Q哥,到处找你都找不到,原来你在这,快回去,领导叫我们出趟差”
未完待续······
往期TOP5文章
CPU:网卡老哥,你到底怎么工作的?的更多相关文章
- 老哥,您看我这篇Java集合,还有机会评优吗?
集合在我们日常开发使用的次数数不胜数,ArrayList/LinkedList/HashMap/HashSet······信手拈来,抬手就拿来用,在 IDE 上龙飞凤舞,但是作为一名合格的优雅的程序猿 ...
- PHP获得计算机的唯一标识[cpu,网卡]
以下是从网上转载来的源码,但是我测试均不能执行,不知道怎么回事,转过来大家可以交流一下 <?php//获取电脑的CPU信息 function OnlyU(){ $a = ''; $b = arr ...
- git学习 c的某位老哥的,(侵删)
Git命令行基本操作 安装Git 网上有很多Git安装教程,如果需要图形界面,windows下建议使用TortoiseGit,linux建议使用Git GUI或者GITK. Git基本配置 git c ...
- 给用过SAP CRM中间件的老哥老姐们讲讲SAP CPI
最近Jerry由于项目需要,又得学习一个新工具:SAP Cloud Platform Integration,简称CPI,以前又叫做HCI - HANA Cloud Platform Integrat ...
- CPU网卡亲和绑定
#!/bin/bash # # Copyright (c) , Intel Corporation # # Redistribution and use in source and binary fo ...
- ArrayList源码解析,老哥,来一起复习一哈?
前言 JDK源码解析系列文章,都是基于JDK8分析的,虽然JDK14已经出来,但是JDK8我还不会,我... 类图 实现了RandomAccess接口,可以随机访问 实现了Cloneable接口,可以 ...
- 老哥你能写篇 SpringCloud Alibaba 全家桶吗? 看视频太累 太枯燥了 !
最喜欢的一句话: 1.01的365次方=37.78343433289 >>>1 0.99的365次方= 0.02551796445229, 每天进步一点点的目标,贵在坚持 前端时间有 ...
- DNS 到底怎么工作的? (How does dns work?)
其实这个问题每次看的时候都觉得很明白,但是很久之后就忘记了,所以这次准备记录下来.深入到这个过程的各个细节之中,以后多看看. Step 1 请求缓存信息: 当你在开始访问一个 www.baidu.co ...
- 老哥你真的知道ArrayList#sublist的正确用法么
我们有这么一个场景,给你一个列表,可以动态的新增,但是最终要求列表升序,要求长度小于20,可以怎么做? 这个还不简单,几行代码就可以了 public List<Integer> trimL ...
随机推荐
- django支持多语言
Django支持多语言切换 下面介绍下如何使网站或APP国际化,让其支持多种语言 . 官网 效果 1.创建locale文件夹 先在项目根目录下创建一个名为locale的文件夹,这个文件夹是用来存放dj ...
- P2966 [USACO09DEC]Cow Toll Paths G
题意描述 Cow Toll Paths G 这道题翻译的是真的不错,特别是第一句话 给定一张有 \(n\) 个点 \(m\) 条边的无向图,每条边有边权,每个点有点权. 两点之间的路径长度为所有边权 ...
- 浮动布局问题多,还是用inline-block吧
说说知识陈旧的问题. 目前我的前端开发知识积累最大的问题就是版本问题,也许我已经经历了很多,尝试了很多, 但是有些知识的版本已经过时了,而我还没有来得及更新它们.更悲剧的可能是有些部分我还没有意识到. ...
- 【日拱一卒】链表——如何实现lru
LRU Redis的内存淘汰机制好几种,如ttl.random.lru. lru(less recently used)即最近最少使用策略,表示在最近一段时间内最少被使用到的Redis键,如果遇到内存 ...
- epoll oneshot
/* Epoll private bits inside the event mask */#define EP_PRIVATE_BITS (EPOLLWAKEUP | EPOLLONESHOT | ...
- 查找数组中第k大的数
问题: 查找出一给定数组中第k大的数.例如[3,2,7,1,8,9,6,5,4],第1大的数是9,第2大的数是8-- 思考:1. 直接从大到小排序,排好序后,第k大的数就是arr[k-1]. 2. ...
- IO复用之poll
主要用一个例程来讲解poll,包含客户端和服务器端. poll函数没有FD_SETSIZE的限制 int poll(struct pollfd * fdarray, unsigned long nfd ...
- fcntl函数用法——设置文件锁
fcntl函数.锁定文件,设置文件锁.设置获取文件锁:F_GETLK .F_SETLK .F_SETLKW文件锁结构,设置好用于fcntl函数的第三个参数.struct flock{ shor ...
- typora 图片存储在COS
背景 一直在使用的markdown编辑器:typora ,在其内部图片默认是存储在本机C盘中的,现想将图片方放到云端存储,节省存储空间 方法 将typora中的图片上传到腾讯云的COS中 参考:链接 ...
- 从ceph对象中提取RBD中的指定文件
前言 之前有个想法,是不是有办法找到rbd中的文件与对象的关系,想了很久但是一直觉得文件系统比较复杂,在fs 层的东西对ceph来说是透明的,并且对象大小是4M,而文件很小,可能在fs层进行了合并,应 ...