写点什么

Nginx 学习书单整理

  • 2019-01-29
  • 本文字数:2742 字

    阅读完需:约 9 分钟

Nginx 学习书单整理

大家好,我是陶辉,之前在华为、阿里、腾讯、思科等公司工作过,现在是杭州智链达公司的联合创始人兼 CTO。我从 09 年开始接触 Nginx,至今已经有 10 年了,对 Nginx 有一些自己独特的见解,分享自己学习 Nginx 的经历与经验,及梳理重难点等等。


以下是“Nginx 到底该怎么学?”的主题纲要。


作为工程师的我们,为什么要学 Nginx?

第一点:Nginx 对整个架构的帮助是非常大的。

2007 年,我从华为来到了腾讯的 QQ 空间,在数据开发组工作。当时 QQ 空间小组也就是十来个人,大概有一亿多用户,同时在线大约在三百万用户,承载在 Apache 和 C++开发的服务器上。因为当时腾讯有蛮低的 ARPO 值(每用户平均收入),每个用户贡献的收入是很少的,所以我们需要每台服务器尽量能够带来更多的价值,能服务更多的用户,就需要在 Apache 上做大量的优化。比如说把它的多进程改成多线程,很多初始化能一次解决的就不要初始化多次、调用多次等等。


但是不管你怎么样做,总有点隔靴搔痒的感觉,你根本没办法做大幅度的优化,因为它的结构已经决定了这些问题的出现。


2009 年我到了思科之后,也遇到了同样问题,但我开始接触 Nginx,发现用 Nginx 改造服务器之后,它大概有 10 倍这样数量级的性能提升。但对于 Apache,你对架构本身没有办法做很大的变动了。这就是我通过实际经历想表达的第一点。

第二点:不能重复造轮子。

什么叫不能重复造轮子?


大概 2014 年,我在阿里 VBC 网络的时候,用因特尔的 DBDT 技术解决方案,做了一个叫 SDN 软件自定义网络。当时我突然发现,你做一些比如网络设备相关东西的时候,它的技术迭代非常慢,而且技术相对保守一些。


这个到底是为什么呐?我现在想明白了,就是我们在互联网背景下,技术是模块依赖的,比如我用 Nginx 来开发,Nginx 的模块都是开放的,我可以基于别人的模块做进一步的开发。别人在 不断迭代模块的之后,我可以享受到优化的好处,这就是所谓的“站在巨人的肩膀上”。


这也就是我想讲的:千万不要重复造轮子。如果 Nginx 能解决,或者说任何一个成熟的框架能解决问题的时候,不要再花时间自己做了。

第三点:还有好的架构。

什么叫好的架构?


我是 2012 年 10 月份去的阿里云,做了架构师。ECS 当时是两个月迭代一次版本,我们团队全年通宵了 23 次,花了两年时间,把线上的五万台服务器重构成一个新的架构,大概是一个月就可以做迭代。


好的架构真的很重要。Nginx 就是个好的架构。


好架构,就是你要有预见性。比如 TCP 协议,它在 1995 年的时候就创立出来了,到现在都没有大改,依旧服务了各种各样的场景。Nginx 也是一样,从 2014 年推出来后基本没多大变化。但它的模块化,是纵向的划分的架构,最底层是事件驱动,基于 EP 的事件驱动,再上面是 HTTP 框架,再上面是 HTTP 模块,再上面是 OpenResty 的 lua。再看横向的划分,比如说我们要做一些 WAF 防火墙的限制,又比如基于 IP 做白名单、黑名单,那它的模块划分很清楚,还比如其他的模块,像 linit 或者 Request 只负责限速,不会自己去获取到用户的真实 IP 再去限速等等。


所以,我说 Nginx 是一个好的架构,而我们学习 Nginx,也可以获取到非常好的架构思维。

我是怎么学 Nginx?

其实,我觉得大家比我幸运很多,现在可以找到很多 Nginx 的学习资料。但在我一开始学 Nginx 的时候,也就是 2009 年吧,网上可查的资料非常少,连英文资料还都只有一本书。我大概只看了一个 10 页教你怎么开发的文档,就开始跟着源码学了。


因为 09 年的时候我大概有五到六年的工作经验,已经形成了一套自己的知识体系,所以对着源码学习相对比较容易。Winter 老师在直播的时候也提到了,知识体系这个点,说我们不断地在学习新的知识点,会觉得很困难,这时候你一定要建立自己的知识体系架构。那知识体系架构最重要的是逻辑性、完备性。所谓的逻辑性,就是把一个新的知识点罗列到之前的知识树状结构中的能力。在《Nginx核心知识100讲》的课程中,你跟着我学,也能梳理出树状结构的知识框架。后续新的知识点,哪怕不是 Nginx,只要是 Web 服务器类的,你都可以归到这知识框架中。


在我看来,学习就是道与术的关系。

学习 Nginx 有哪些好书推荐?

我认为有三个知识点一定要学:


1、第一个知识就是 HTTP 学习,《HTTP 权威指南》是一本很好的书;


2、第二个是 TCP 协议一定要学习,因为 Nginx 在处理的是性能,所以我们一定要了解 TCP 协议。有一本书叫《TCP/IP 详解卷一:协议》,其实它有三卷,第二卷、第三卷比较长,大家如果没有时间就不要看了。但大家一定要看卷一,重点是看 TCP 协议,大概也就是八、九章的样子。


3、第三个是一定要了解 Linux 的内核。大定不要一听到内核就觉得好恐怖啊,推荐一本书叫《深入理解 Linux 内核》,这本书对于前端同学来说,就比较恐怖了,学起来会非常的吃力,甚至一些后端同学第一次学也会感到吃力。


我再推荐一本书,叫做《Lniux 内核设计与实现》,讲的是比较浅,但一定要从第一章开始看,从进程、内存开始讲。你大概看完一半的时候,就会对一套体系非常的熟悉了。


其实,如果你真的要学 Nginx 的话,我首要推荐的是一个英文网站:Nginx.org


虽然不是中文,但大家不要怕,因为网站上没有什么大段的内容,就是一个一个分析它的指令,大部分指令还是讲的很到位的。不过有些指令讲得也非常的浅,你也可以结合我的课程《Nginx 核心知识 100 讲》来学习,我会专门扩展去讲解一些指令。


但总而言之,对于 Nginx 学习者来说,吃透这个网站是很重要的。


第二个是 Nginx.com,就是 Nginx PLUS 那个官网,它有一个,那个中间有个叫 Blog,叫博客那栏,那里面有很多很好的文章,像关于 NginxPlus,的就不用管了,因为它是广告,它就像你买那个 Nginx Plusd。但 Nginx 又不开源,这个就比较糟糕,那种的就不用看,但是就是关于它的一些新的特性的,这个一定要好好看一看。


第三个就是我的书《深入理解 Nginx;模块开发与架构解析》。这本书主要讲的是模块开发,因为我当时工作要写模块开发,但市面上没有任何一本书来讲模块开发,于是就有了这本书。我为了讲清楚模块开发,又讲了一些架构的东西,这个是有参考意义的。但我建议大家一定要先看完《HTTP 权威指南》、《Linux 内核设计与实现》,再去看这本书,会更容易轻松一点。


最后就是源码一定要看。



《Nginx核心知识100讲》的第六部分课程中,我会有大概会有 10 节课去讲 OpenResty。结合了之前的 Nginx 基础架构、HTTP 模块、反向代理与负载均衡等学习,掌握 OpenResty 会很简单。OpenResty 的官网上有很多错误的,主要在 Github 上有些指令的错误。但因为你有之前的知识认知,你会发现 Github 上没有讲到的东西,你也会用。


Nginx 的知识架构也就是这四个点:HTTP 框架、进程架构、变量、Openresty。OpenResty 是我认为非常重要的一点。


戳我看直播原版视频。


2019-01-29 14:379312

评论 1 条评论

发布
用户头像
ARPU
2019-01-29 14:59
回复
没有更多了
发现更多内容

创业7年复盘,中美企业服务市场差异浅析

Kyligence

AI 数据分析

Java 编程指南:入门,语法与学习方法

小万哥

Java 程序人生 编程语言 软件工程 后端开发

10V单通道负载开关

梦笔生花

【亿级数据专题】「分布式消息引擎」 盘点本年度我们探索服务的保障容量的三大关键方案实现

洛神灬殇

分布式 熔断 限流 降级 2024年第二十七篇文章

Alert 趋势图与原始指标图整体优化、指标趋势图查询异常中台功能

博睿数据

「一手好牌」|博睿数据新年掼蛋礼盒:开年好运,事业高飞!

博睿数据

XMind 转 Excel 与 CSV 的思路与实现

牧遥

Excel XMind 测试工具 csv Java’

提升系统管理:监控和可观察性在DevOps中的作用

禅道项目管理

项目管理 DevOps 系统管理

如何对混合日志进行自动化解析

华为云开发者联盟

开发 华为云 华为云开发者联盟

稀疏场景高性能训练方案演变|京东广告算法架构体系最佳实践

京东零售技术

人工智能 架构 算法 GPU算力

《深入理解计算机系统(原书第3版)》PDF

程序员李木子

linux的find命令常用说明

百度搜索:蓝易云

云计算 Linux 运维 云服务器 find

如何解决系统报错:nf_conntrack: table full, dropping packets

百度搜索:蓝易云

云计算 Linux 运维 服务器 云服务器

IPQ9574 and QCN9274 Industrial grade and commercial difference? Performance, transmission, etc

wifi6-yiyi

qcn9274 ipq9574

【年后跳槽必看篇-非广告】Kafka核心知识点-第四章

派大星

kafka Java’

四方维ECAD模型成为元器件的新标配

财见

面试官:什么是JIT、逃逸分析、锁消除、栈上分配和标量替换?

王磊

Java 面试

第38期 | GPTSecurity周报

云起无垠

Covalent Network:全新链上协议收入体系,财务透明革命引领者

股市老人

Linux系统gunzip命令有何作用?如何使用?

百度搜索:蓝易云

云计算 Linux 运维 云服务器 gunzip

使用 HashiCorp Vault 保护 NGINX 中的 SSL 私钥

NGINX开源社区

HashiCorp SSL/TLS nginx 开源版 安全防护 保护 SSL 密钥

一文带你简单了解多租户模型定义以及好处

行云管家

SaaS 多租户

Wireshark中的ARP协议包分析

小齐写代码

Nginx 学习书单整理_语言 & 开发_陶辉_InfoQ精选文章