网络协议是每个程序员入门的必修课,但是完全掌握网络协议知识并进行实际应用却并非易事。在本书中,作者将结合自己从业多年的“泣血”经验,以通俗易懂、更加贴近日常生活的方式,从底层到上层对基础、常用、重要的网络协议进行解析,并将深入分析网络协议在云计算、容器和微服务等领域的应用和实践。本书将帮助入门级程序员深入、直观地理解网络协议基础概念和原理,构建一个完整、精准的网络协议知识框架;也会帮助有一定工作经验的程序员填补知识漏洞、打通知识体系。
网易云首席架构师设坛开讲必修基功 原理妙解到实战雷区再到新技术应用
为什么要写网络协议
写一本通俗地讲解网络协议的书,一直是我的一个梦想。
在我十多年的职业生涯中,对网络协议爱恨交加,学习过程大致分为以下三个阶段。
第一阶段:难且无从下手。虽然我们在大学都学过网络协议,但是感觉网络协议的知识点非常多、非常复杂。学的时候就浑浑噩噩,真正到了实践中更是糊里糊涂,一旦工作中遇到了网络问题,除了会简单地ping 几下,基本没有什么解决问题的思路。然而当我想拿起书来学习,或者看一些官方文档的时候,各种生僻的专业词汇马上扑面而来。每了解其中的一个词汇,都要看n 篇文章,读n 本书,导致一篇即使很短的有关网络技术的文章也要几个星期才能看完。这严重打击着我的自信心,并且很容易让人在技术的海洋中迷失自我,从而产生“从入门到放
弃”的冲动。
第二阶段:苦且绕不过去。经过多次放弃之后,我发现在我的职业生涯中,网络这一关无论如何也绕不过去。本来觉得写Java 程序时可以依赖别人的库,所以就不用关心这么多底层的技术了,但是到后来才发现,服务数量一多,吞吐量一大,我们关心的不再仅仅是某个Java 应用,而是要提升整个集群的性能,这时网络问题就会出现。而且大规模的微服务架构必定要上云、使用VPC 网络,这时就必定要考虑双活和灾备,必定要做各个层次的负载均衡,这些都需要网络方面的技术。既然绕不过去,那就必须“啃”下它,于是我就进入了暗无天日的网络协议学习的过程。见山开路、遇水搭桥,遇到一个知识点攻克一个,再将其写到博客或者笔记里面。有时候要看很多文章和书才能攻克一个知识点,但我还是每天下班抱着网络技术相关的文章和书看,直到将各个零散的知识点串连了起来。后来在定位网络问题的时候,我开始有了自己的思路,这时才感觉算是暂时趟过了这条河。
第三阶段:有趣且受益匪浅。网络协议和变化万千的前沿技术不同,它的变化比较小,一旦掌握到一定程度,就会一直受益。技术变化很快,这几年OpenStack、Docker、Mesos、Kubernetes、微服务、Serverless、AIOps 等技术层出不穷,让大多数技术人员应接不暇,但是掌握了基础知识以后,我反而发现很多技术看起来“轰轰烈烈”,扒下外衣,其实本质还是操作系统、计算机网络、算法与数据结构、编译原理、计算机组成与系统结构。如果基础打好了,最大的收益就是,在最新的技术出来以后,只要经过短时间的学习,就很容易上手,就能在新技术的滚滚浪潮中保持快速学习的能力。这点让我受益匪浅。
既然网络协议既是基础,又绕不过去,还这么难,但是趟过去之后又不怎么变,收益越来越大,那为什么不写一本书,给大家一点可借鉴的经验,帮助大家尽快通过第一和第二阶段呢?
为什么要趣谈
决定写网络协议,但是怎样写呢?其实网络协议相关的文章已经非常多了,但是我自己学习网络协议的时候,还是遇到了很多的困难。
网络协议知识点太多,学完记不住。大部分读者应该都学过计算机网络课程,学的时候感觉并不难,尤其这门课没有公式,更像是文科的东西。学了一大堆东西,也背了一大堆东西,但是最终应付完考试之后,都“还给了老师”。网上有很多关于网络协议的文章,看的时候感觉别人说得很有道理,自己好像理解了,但是经不住问,一问就会发现,大概的流程明白了,可是很多细节还是不知道。从能看懂到能真正明白,中间还有很长一段路要走。每次都感觉自己好像学会了,但实际应用的时候依旧无从下手。虽然很多细节都摸索得差不多了,但是当自己去应用和调试时,才发现还是没有任何思路。比如,当创建出来的虚拟机不能上网时,还是无从下手,学过的很多东西,似乎都用不上。
我把这种现象总结为:一看觉得懂,一问就打鼓,一用就糊涂。
所以本书使用了“趣谈”这种方式,它可以解决从“入门到放弃”的问题,把晦涩的知识点和一些有趣的故事通过比喻的方式结合起来,这样更容易帮助读者系统、深入地了解网络技术的知识点和大致的工作流程。
当然用来做比喻的例子和真实的知识点以及工作流程会有一定的差别,但是没有关系,我们的大脑应该是一个缓存,而不是一个硬盘,通过通俗易懂的方式记住知识体系和大致流程,真正到解决问题的时候,再去查阅更加准确的资料,就可以了。
这本书的特点
本书有以下几个特点。
第一,会从身边经常见到的事情出发,用讲故事的方式来讲解各种协议,然后慢慢扩大到不熟悉的领域。例如,每个人都会使用查看IP 地址的命令,我们就从这个命令开始,展开讲解一些相关概念。每个人都在大学宿舍组过简单的网络来打游戏,我们就从宿舍网络涉及的最简单的网络概念开始讲,然后说到办公室网络,再说到日常常用的与上网、购物、视频下载等活动相关的网络协议,最后才说到最陌生的数据中心。说到这里的时候,很多概念已经在前面的“宿舍”和“办公室”的例子中都出现过,因此更容易接受和理解。
第二,讲解网络协议时会更加贴近使用场景,将各个层次的关系串连起来,而非孤立地讲解某个概念。常见的计算机网络课程往往会按照网络分层,一层一层地讲,却很少讲层与层之间的关系。例如,我们在学习路由协议的时候,在真实场景中,这么多的算法和二层是什么关系呢?和四层又是什么关系呢?再比如,我们在真实的网络通信中访问一个网站、进行一次支付,那么在TCP 三次握手的时候,IP 层在干什么?MAC 层在干什么?这些内容本书都会逐一讲解。
第三,在讲解完各个层次的协议之后,会讲述如何在当前热门领域(比如云计算、容器和微服务)中使用这些协议。
通过学习本书,读者一方面可以了解这些网络协议的真实应用场景,另一方面也可以通过上手使用云计算、容器、微服务来进一步加深对于网络协议的理解。