OpenResty从入门到实战 / 系统掌握一款高性能开发利器
温铭
OpenResty软件基金会第一任主席,Apache APISIX 项目 VP
 
  • 课程目录
  • 课程介绍
  • 开篇词 | OpenResty,为你打开高性能开发的大门

    掌握OpenResty,你可以同时拥有脚本语言的开发效率和迭代速度,以及 NGINX C模块的高并发和高性能优势。

  • 01 | 初探OpenResty的三大特性

    接下来,我重点来介绍下,OpenResty 这个开源项目值得称道和学习的几个地方。

  • 02 | 如何写出你的“hello world”?

    为什么不能直接从操作系统的官方仓库安装,而是需要先设置另外一个仓库地址?

  • 03 | 揪出隐藏在背后的那些子项目

    希望你学完今天的内容后,能够了解更多 OpenResty 的项目。

  • 04 | 如何管理第三方包?从包管理工具luarocks和opm说起

    本节我们就来一起了解下,应该从什么渠道来找到这些第三方库。

  • 05 | [视频]opm项目导读

    你将会熟悉一个OpenResty 项目的结构和开发流程。

  • 06 | OpenResty 中用到的 NGINX 知识

    在 OpenResty 中用到的都是 Nginx 的基础知识,主要涉及到配置、主从进程、执行阶段等。

  • 07 | 带你快速上手 Lua

    下面,我带你来快速熟悉下 Lua 的数据类型和语法。

  • 08 | LuaJIT分支和标准Lua有什么不同?

    这节课,我们来学习下 OpenResty 的另一块基石:LuaJIT。

  • 09 | 为什么 lua-resty-core 性能更高一些?

    让我们以一个简单的 API 为例,一起看下 Lua C API 和 FFI 的实现有何不同。

  • 10 | JIT编译器的死穴:为什么要避免使用 NYI ?

    请优先使用 OpenResty 提供的 API,而不是 Lua 的标准库函数。

  • 11 | 剖析Lua唯一的数据结构table和metatable特性

    今天我们一起学习下LuaJIT 中唯一的数据结构:table。

  • 12 | 高手秘诀:识别Lua的独有概念和坑

    今天我再为你介绍一些Lua 独有的或不太常用的概念,以及 OpenResty 中常见的 Lua 的坑。

  • 13 | [视频]实战:基于FFI实现的lua-resty-lrucache

    你可以弄清楚要如何使用 FFI,并了解一个完整的 lua-resty 库应该包括哪些必要内容。

  • 14 | 答疑(一):Lua 规则和 NGINX 配置文件产生冲突怎么办?

    OpenResty 需要特定版本的 LuaJIT 才能正常运行。

  • 15 | OpenResty 和别的开发平台有什么不同?

    今天我们来熟悉下 OpenResty 的原理和基本概念。

  • 16 | 秒杀大多数开发问题的两个利器:文档和测试案例

    在学习了 OpenResty 的原理和几个重要概念后,我们终于要开始 API 的学习了。

  • 17 | 为什么能成为更好的Web服务器?动态处理请求和响应是关键

    今天这节课,我们来看一下 OpenResty 如何处理终端请求和响应。

  • 18 | worker间的通信法宝:最重要的数据结构之shared dict

    共享内存字典shared dict,是你在 OpenResty 编程中最为重要的数据结构。

  • 19 | OpenResty 的核心和精髓:cosocket

    今天我们学习了cosocket 的基本原理和API、指令,并通过实际例子熟悉了TCP 相关的 API 应该如何使用。

  • 20 | 超越 Web 服务器:特权进程和定时任务

    我们今天就挑选几个OpenResty 中超越 Web 服务器的功能,来介绍一下。

  • 21 | 带你玩转时间、正则表达式等常用API

    今天我们再来了解下其他一些通用的 API,主要和正则表达式、时间、进程等相关。

  • 22 | [视频]从一个安全漏洞说起,探寻API性能和安全的平衡

    安全,是一个永恒的话题,不管你是写开发业务代码,还是做底层的架构,都离不开安全方面的考虑。

  • 23 | [视频]导读lua-resty-requests:优秀的lua-resty-*是如何编写的?

    如何在众多的 lua-resty HTTP client 中,选择一个最好、最适合自己的第三方库呢?

  • 24 | 实战:处理四层流量,实现Memcached Server

    今天,我带你一起用 OpenResty 来实现一个 memcached server。

  • 25 | 答疑(二):特权进程的权限到底是什么?

    我们一般用特权进程来处理的是清理日志、重启 OpenResty 自身等需要高权限的任务。

  • 26 | 代码贡献者的拦路虎:test::nginx 简介

    测试,是软件开发中必不可少的一个重要环节。

  • 27 | test::nginx 包罗万象的测试方法

    在本节课中,我会带你来熟悉下 test::nginx 中经常用到的指令和测试方法。

  • 28 | test::nginx 还可以这样用?

    如果学完今天的课程,你在 test::nginx 上的理解,绝对可以进入全球 Top 100。

  • 29 | 最容易失准的性能测试?你需要压测工具界的“悍马”wrk

    如何做一个科学严谨的性能测试呢?今天这节课,且听我娓娓道来。

  • 30 | 答疑(三)如何搭建测试的网络结构?

    性能测试工具可能存在协调遗漏问题,在分析工具的延时数据时,你一定要特别留意。

  • 31 | 性能下降10倍的真凶:阻塞函数

    了解哪些行为是危险的,并避免使用它们,是性能优化的第一步。

  • 32 | 让人又恨又爱的字符串操作

    从今天开始,我们就要进入性能优化的核心部分了。

  • 33 | 性能提升10倍的秘诀:必须用好 table

    今天,我就带你专门来聊聊table 操作对性能的影响。

  • 34 | 特别放送:OpenResty编码指南

    我根据自己在OpenResty 相关开源项目中的经验,总结了一下 OpenResty 的编码风格文档分享给你。

  • 35 | [视频]实际项目中的性能优化:ingress-nginx中的几个PR解读

    如何运用学习的性能优化方面的知识,来发现开源项目的性能问题呢?

  • 36 | 盘点OpenResty的各种调试手段

    在 OpenResty 的世界中,SystemTap 和火焰图,才是处理棘手问题和性能问题的标准利器。

  • 37 | systemtap-toolkit和stapxx:如何用数据搞定“疑难杂症”?

    在 OpenResty 的世界中,学会使用这些工具是你进阶的必经之路,也是和其他开发者沟通的非常有效的方式。

  • 38 | [视频]巧用wrk和火焰图,科学定位性能瓶颈

    今天的视频课,我会用一个开源的小项目来演示一下,如何通过 wrk 和火焰图来优化代码。

  • 39 | 高性能的关键:shared dict 缓存和 lru 缓存

    一个生产环境的缓存系统,需要根据自己的业务场景和系统瓶颈,来找出最好的方案。这是一门平衡的艺术。

  • 40 | 缓存与风暴并存,谁说缓存风暴不可避免?

    每当遇到一些有趣的实现,我们总是希望能够看看它的源码是如何实现的,这也是开源的好处之一。

  • 41 | lua-resty-* 封装,让你远离多级缓存之痛

    有了多层缓存,服务端的性能才能得到最大限度的保证,而这中间又隐藏了很多的细节。

  • 42 | 如何应对突发流量:漏桶和令牌桶的概念

    流量控制是需要在业务稳定和用户体验之间做平衡的。

  • 43 | 灵活实现动态限流限速,其实没有那么难

    OpenResty 使用 Lua 脚本的方式,恰好能够弥补 Nginx 在这方面的缺失,形成了有效的互补。

  • 44 | OpenResty 的杀手锏:动态

    动态,指的是程序可以在运行时、在不重新加载的情况下,去修改参数、配置,乃至修改自身的代码。

  • 45 | 不得不提的能力外延:OpenResty常用的第三方库

    对于开发语言和平台来讲,很多时候的学习,其实是对标准库和第三方库的学习,语法本身并不用花费很多的时间。

  • 46 | 答疑(四):共享字典的缓存是必须的吗?

    性能优化要从宏观的视角来看待,这是你特别需要注意的一个点。

  • 47 | 微服务API网关搭建三步曲(一)

    今天这节课,我们介绍了微服务 API 网关的作用、功能、核心组件和抽象概念,它们都是 API 网关的基础。

  • 48 | 微服务API网关搭建三步曲(二)

    今天,我们就分别来看下,路由、插件、schema 和存储这四个核心组件的技术选型问题。

  • 49 | 微服务API网关搭建三步曲(三)

    让我们用一个最小的示例来把之前选型的组件,按照设计的蓝图,拼装运行起来吧!

  • 50 | 答疑(五):如何在工作中引入 OpenResty?

    从替代 Nginx 的角度来切入,然后慢慢扩散来使用OpenResty ,是一个不错的注意。

  • 结束语 | 行百里者半九十

    互动所产生的价值,远比单向的知识输出更有意义,也更加持久,这样我才算是走完了最后的十里路。

【仅限 100 个名额 | 立省 ¥40】

拼团+口令「maimaimai」到手仅 ¥89,立省 ¥40,仅限 100 个名额

你将获得

  • 构建OpenResty完整知识体系;
  • 高性能OpenResty编码指南;
  • 开源项目源码分析与实战;
  • 从0搭建微服务API网关。

讲师介绍

温铭,OpenResty 软件基金会第一任主席,《OpenResty 最佳实践》开源书的发起人和作者,Apache APISIX 项目 VP。曾任某开源商业公司合伙人,前 360 开源技术委员会委员。他在互联网安全公司工作了 10 年,负责开发过云查杀、反钓鱼和企业安全产品。

课程介绍

对于每一个服务端开发工程师来说,高性能、高并发都是避不开的话题,谁不希望开发高性能的服务端,做出能支持千万甚至上亿用户的系统呢?

不管你的开发语言和平台是什么,学会 OpenResty 都会对你有所裨益。使用OpenResty,你可以用 Lua 语言来进行字符串和数值运算、查询数据库、发送 HTTP 请求、执行定时任务、调用外部命令等,还可以用 FFI 的方式调用外部 C 函数。这基本上可以满足服务端开发所需的所有功能。

可以说,掌握了 OpenResty,你就可以同时拥有脚本语言的开发效率和迭代速度,以及 NGINX C 模块的高并发和高性能优势

不过,OpenResty 的学习资料还比较少,官方也只有 API 文档,而网上能找到的资料也不够系统。可以说,绝大部分的 OpenResty 使用者都是在摸着石头过河,很难实现系统、权威的学习。

在这个专栏里,温铭将带你轻松快速入门,并给你描绘 OpenResty 的全貌,建立完整的知识体系;同时,他会串联整个专栏来实战应用,带你从零开始搭建一个 API 网关。为了让你接触更真实的使用场景,温铭还在专栏里特别增加了多节视频课程,进行开源项目的源码分析和实战演练,帮你真正掌握OpenResty这款开发利器。

根据 OpenResty 使用者的现状分析,专栏内容分为5大模块。

模块一,入门篇。OpenResty 由 NGINX 和 LuaJIT 两部分构成,这一模块会介绍它们的基础知识,以及其中经常遇到的缺陷与陷阱;同时会带你浏览下OpenResty 仓库的近 70 个项目。虽然OpenResty 经常被叫做 ngx-lua,但 lua-nginx-module 仅仅是冰山一角,你需要清晰的全局观来学习 OpenResty 的“真面目”,不能“身在此山中”。

模块二,API篇。这是 OpenResty 对外暴露的 Lua 接口,也是你编写 OpenResty 代码最常用到的部分。这一模块会把这些指令和 API 分门别类逐步介绍给你,并引导你思考一些易忽略的关键点,比如,这些 API 为什么这么设计?为什么要增加一些看上去和 NGINX 无关的功能?希望能让你知其然,更知其所以然。

模块三,测试篇。这可能是本专栏最“高冷”的部分,不少 OpenResty 的代码贡献者都在编写测试案例时遇到过困难。test::nginx 功能异常强大,但也有很高的学习门槛,就连详细文档也不足以填平它。除此之外,这一部分还会带你讨论服务端性能测试,作为 OpenResty 中的最佳实践,在你测试 Java、Go、Node.js 等其他语言开发的系统时,它一样适用。

模块四,性能优化篇。OpenResty 的性能优化技巧,一直是开发者最关注的问题。这个模块会提供 OpenResty 的编码指南,让你从一开始写代码时,就能规避性能问题;并且会手把手地教你,如何使用火焰图这种科学、可量化的工具来定位性能问题,而不是依靠猜测。

模块五,实战篇。OpenResty 社区中有一个很明显的趋势,就是越来越多的开发者把 OpenResty 用在 API 网关的开发中,这是一个非常明智和务实的选择。这个模块会带你把前面所学的知识串联起来,搭建出一个 API 网关的雏形。你可以在此基础上,直接添加自己的模块来实现业务需求,不用再重新造轮子。

课程目录

特别放送

订阅须知