Preface?前 言为什么写这本书在接手安防云任务之前,我做了近10年传统安防分布式平台的工作。安防云任务是基于云计算平台和P2P技术向用户提供SaaS服务。最初我的方案是将我们熟悉的分布式平台改造成云服务,进行互联网部署。
针对消费级摄像机的应用,我们对服务进行了裁剪,只留下几个服务器。但是需要几个资深的C++服务器开发工程师提供技术支持。后来,新来的架构师经过一段时间的消化后,提出了Nginx+Lua+Redis架构。他一个人只花费一个多月的时间就把业务服务写好了。这件事情让我感受到了Nginx+Lua的魅力。
Nginx+Lua架构带来的改变还远不止节约时间和成本。从做大型系统的角度来看,它还会带来更多的东西:
调试方便:因为它不需要编译代码,相关访问模块是成熟稳定的,只需要调试新加的业务代码即可。大型系统特别是分布式系统,调试一个功能或代码的链条太长了,非常容易出错。
降低耦合:因为架构的限制,代码只能在必需的阶段管理器中开发,代码是一个个.lua文件,耦合性大大降低。
框架良好:因为先进的异步式多进程架构,可以充分利用系统资源。如果自行开发并维护这样一个框架,需要大量的人力、物力。
上手容易:Lua代码良好的结构和可读性,使其上手速度更快。团队成员经过快速培训就可以上手。
在学习和使用ngx_lua的过程中我发现,网络上资料其实非常多,但是非常零散,没有整体性。虽然技术本身是很清晰和易用的,但是对于刚接触这门技术的开发者来说,想要有条理、系统地把这些知识学完,可能会走一些弯路。因为很多资料已经过时了,甄别和调试会耗费很多时间和精力,同时查阅英文文档也比较花时间。于是,我就有了把自己的学习过程和心得整理成书的想法。
随后的时间里,我将自己学习Nginx下Lua开发的思路,以及这个过程中的资料一点点总结出来加以整理,终成本书。希望本书可以帮助跟我有一样需求的研发工程师快速了解并掌握Nginx下Lua开发技术。
本书的主要内容和特色通常我们学习一门语言、一门技术的时候,都是这样一个过程:初学这项技术时,我们通常需要知道Lua语言的细节,需要知道Nginx的结构;当我们着手学习时,首先需要搭建一个学习环境,以便了解系统的结构和运行机制,同时用于编写测试代码;运行第一个测试代码的时候,需要对Nginx进行配置,但是并不熟悉Nginx的配置,对于nginx.conf里的内容比较头疼;等到我们掌握了这项开发技术,开始业务系统开发了,又往往需要针对具体问题查找配置指令的用法和参数,以及查阅API的详细用法。
所以,本书按照这样的不同需求,对Nginx下Lua开发技术的不同关注点做了描述。
Nginx的基本知识,包含Nginx的使用、配置、安装、技术架构、技术特点、主要工作流程等。
外围关系型数据库、NoSQL数据库、缓存等的使用范围、安装、使用方法、配置,如MySQL、PostgreSQL、MongoDB、Redis、Memcached。
Lua语法详解,包含Lua系统库。
Lua常用库,包含Redis、MySQL、Memcached、PostgreSQL、MongoDB、Bit、lfs、restry.http、lcurl、FFI、cjson、Template、WebSocket。
两个相对完整的Lua实例,结合实例以巩固涉及的知识点。
ngx_lua的配置指令和API,详细介绍了每一个官方指令和API。
我希望无论是对于Nginx Lua的初学者,还是对于经验丰富的开发者,都可以通过本书学到基础知识,找到常用库的API说明,而不用查阅其他资料及官方英文文档。
本书面向的读者本书适合初学Nginx下Lua开发的工程师使用。通过本书可以比较系统地学习Lua语言,学习框架下经常用到的各组件使用方法,学习Nginx下Lua程序开发;可以参照本书的内容搭建学习环境,逐一测试各组件访问代码,并可通过后面的例子编写自己的访问代码和访问库。
本书适合有经验的Nginx和Lua开发工程师使用。通过本书可以快速查阅相关数据库、缓存、库的使用方法;可以查阅Nginx配置指令;还可以查阅ngx_lua配置指令和API。
本书同样适合做服务器端开发的资深工程师使用。书中讲解了Nginx的核心架构和主要的工作流程,也讲解了Nginx为了提高性能和并发所使用的一些关键技术,这些技术和算法对我们开发自己的高性能服务器有重要指导意义。
如何阅读本书本书主要分五部分:
第一部分(第1~5章)介绍Nginx的基本操作,同时讲解了MySQL、PostgreSQL、Redis、Memcached、MongoDB、OpenResty的基本操作。通过对本部分的学习可以掌握这些服务的安装和使用方法,一般用于研发环境的搭建。这里还讲解了Nginx核心技术和工作流程,用于帮助读者进一步掌握Nginx的架构和流程。各个层次的读者都可以从本部分读起。
第二部分(第6~7章)详细讲解了Lua脚本语言和Lua通用库。学习Lua语言或查阅Lua语法的初学者可以直接阅读该部分相应章节。
第三部分(第8~10章)讲解了在Nginx开发中经常使用的一些技术,如JSON数据交换格式、nginx.conf配置方法和配置指令;还讲解了Nginx下Lua开发的实现机制。学习Nginx配置的读者,学习和查阅JSON的读者可以直接阅读该部分相应章节,也可以跳过其他章节,直接学习Nginx下Lua的实现机制。
第四部分(第11~26章)详细介绍了常用Lua库和数据库等组件的使用方法,包括Redis、MySQL、Memcached、PostgreSQL、MongoDB、Bit、lfs、restry.http、lcurl、FFI、cjson、Template、WebSocket。要了解和学习这些内容的读者,可以直接阅读对应章节。这里同时给出了两个Lua编程实例代码,要总体了解这项编程技术的读者可直接翻阅相应章节。
第五部分(第27~28章)详细介绍了ngx_lua的配置指令和ngx_lua API,目的是帮助读者在工作中快速检索配置指令和API。
勘误和资源由于时间有限,技术能力有限,虽然已经尽量客观,在写作过程中排除自己主观的内容,但难免有错误和不准确的地方,热忱希望你的批评和指正。
欢迎通过邮箱和我联系:
[email protected]。
致谢首先需要感谢我的太太一直以来对我的信任和支持,她是我一路走来的动力。写这本书的时候,九哥已经10岁了,他已经知道我在做什么了,他以我为荣,我也以他为傲。感谢我的丈人、丈母娘对我们的爱和一直以来的帮助。
写这本书的时候,我的父母又来到了我们的身边,为了和我们年轻人相处得更融洽,他们做出了巨大的改变。
最后要感谢出版社的杨福川和李艺,没有你们的努力是不会见到这本书的。感谢你们的支持和信任!