OpenResty从入门到实战
温铭
OpenResty软件基金会主席,《OpenResty 最佳实践》作者
立即订阅
4332 人已学习
课程目录
已完结 52 讲
0/4登录后,你可以任选4讲全文学习。
开篇词 (1讲)
开篇词 | OpenResty,为你打开高性能开发的大门
免费
入门篇 (14讲)
01 | 初探OpenResty的三大特性
02 | 如何写出你的“hello world”?
03 | 揪出隐藏在背后的那些子项目
04 | 如何管理第三方包?从包管理工具luarocks和opm说起
05 | [视频]opm项目导读
06 | OpenResty 中用到的 NGINX 知识
07 | 带你快速上手 Lua
08 | LuaJIT分支和标准Lua有什么不同?
09 | 为什么 lua-resty-core 性能更高一些?
10 | JIT编译器的死穴:为什么要避免使用 NYI ?
11 | 剖析Lua唯一的数据结构table和metatable特性
12 | 高手秘诀:识别Lua的独有概念和坑
13 | [视频]实战:基于FFI实现的lua-resty-lrucache
14 | 答疑(一):Lua 规则和 NGINX 配置文件产生冲突怎么办?
API篇 (11讲)
15 | OpenResty 和别的开发平台有什么不同?
16 | 秒杀大多数开发问题的两个利器:文档和测试案例
17 | 为什么能成为更好的Web服务器?动态处理请求和响应是关键
18 | worker间的通信法宝:最重要的数据结构之shared dict
19 | OpenResty 的核心和精髓:cosocket
20 | 超越 Web 服务器:特权进程和定时任务
21 | 带你玩转时间、正则表达式等常用API
22 | [视频]从一个安全漏洞说起,探寻API性能和安全的平衡
23 | [视频]导读lua-resty-requests:优秀的lua-resty-*是如何编写的?
24 | 实战:处理四层流量,实现Memcached Server
25 | 答疑(二):特权进程的权限到底是什么?
测试篇 (5讲)
26 | 代码贡献者的拦路虎:test::nginx 简介
27 | test::nginx 包罗万象的测试方法
28 | test::nginx 还可以这样用?
29 | 最容易失准的性能测试?你需要压测工具界的“悍马”wrk
30 | 答疑(三)如何搭建测试的网络结构?
性能优化篇 (16讲)
31 | 性能下降10倍的真凶:阻塞函数
32 | 让人又恨又爱的字符串操作
33 | 性能提升10倍的秘诀:必须用好 table
34 | 特别放送:OpenResty编码指南
35 | [视频]实际项目中的性能优化:ingress-nginx中的几个PR解读
36 | 盘点OpenResty的各种调试手段
37 | systemtap-toolkit和stapxx:如何用数据搞定“疑难杂症”?
38 | [视频]巧用wrk和火焰图,科学定位性能瓶颈
39 | 高性能的关键:shared dict 缓存和 lru 缓存
40 | 缓存与风暴并存,谁说缓存风暴不可避免?
41 | lua-resty-* 封装,让你远离多级缓存之痛
42 | 如何应对突发流量:漏桶和令牌桶的概念
43 | 灵活实现动态限流限速,其实没有那么难
44 | OpenResty 的杀手锏:动态
45 | 不得不提的能力外延:OpenResty常用的第三方库
46 | 答疑(四):共享字典的缓存是必须的吗?
API网关篇 (4讲)
47 | 微服务API网关搭建三步曲(一)
48 | 微服务API网关搭建三步曲(二)
49 | 微服务API网关搭建三步曲(三)
50 | 答疑(五):如何在工作中引入 OpenResty?
结束语 (1讲)
结束语 | 行百里者半九十
OpenResty从入门到实战
登录|注册

01 | 初探OpenResty的三大特性

温铭 2019-05-27
你好,我是温铭。
开篇词里我们说过,OpenResty 的优势显而易见。不过,在具体学习之前,让我们先简单回顾下 OpenResty 的发展过程,这有助于你对后面内容有更好的理解。

OpenResty 的发展

OpenResty 并不像其他的开发语言一样从零开始搭建,而是基于成熟的开源组件——NGINX 和 LuaJIT。OpenResty 诞生于 2007 年,不过,它的第一个版本并没有选择 Lua,而是用了 Perl,这跟作者章亦春的技术偏好有很大关系。
但 Perl 的性能远远不能达到要求,于是,在第二个版本中,Perl 就被 Lua 给替换了。 不过,在 OpenResty 官方的项目中,Perl 依然占据着重要的角色,OpenResty 工程化方面都是用 Perl 来构建,比如测试框架、Linter、CLI 等,后面我们也会逐步介绍。
后来,章亦春离开了淘宝,加入了美国的 CDN 公司 Cloudflare。因为 OpenResty 高性能和动态的优势很适合 CDN 的业务需求,很快, OpenResty 就成为 CDN 的技术标准。 通过丰富的 lua-resty 库,OpenResty 开始逐渐摆脱 NGINX 的影子,形成自己的生态体系,在 API 网关、软 WAF 等领域被广泛使用。
取消
完成
0/1000字
划线
笔记
复制
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
该试读文章来自付费专栏《OpenResty从入门到实战》,如需阅读全部文章,
请订阅文章所属专栏。
立即订阅
登录 后留言

精选留言(25)

  • 行者
    同步异步说的是代码,调用就有返回是同步,反之是异步。
    阻塞非阻塞说的是cpu,apu要等待就是阻塞,反之非阻塞。

    非阻塞并不能缩减rt时间,其最大的优点是可以服务更多的请求,达到c100k。

    针对ff同学的问题,阻塞非阻塞对于代码来说是,仅仅是底层实现不同。
    2019-05-27
    22
  • zhang
    分享一篇以前学openresty 时写的笔记,当时处于一个阅读过nginx源码,但是没有实际使用或者开发nginx的情况,另外个人的描述描述能力也比较差,很多知识储备不足。

    当时写这篇笔记并不是对源码进行解读,只是站在一个有什么功能,我应该如何实现它,它是如何做的,这样一个角度去分析的。

    希望这篇笔记可以让大家有一定收获,也希望我们可以互相扶持,一起坚持下去,学好这门课程。


    http://note.youdao.com/noteshare?id=965c9f034a82ffb0f8b4de6ca81f3e73

    作者回复: 👍 一起学习

    2019-05-27
    11
  • 一步
    看了下 openresty github 仓库 https://github.com/openresty/openresty 发现 t文件夹下没有什么测试文件,这个是需要看每个相关的模块的仓库吗? 又看了 https://github.com/openresty/lua-nginx-module 这个模块发现 t文件夹下是有测试文件的

    作者回复: https://github.com/openresty/openresty 是用于打源码包的项目,所以测试案例不多。
    是的,需要看这个子项目的仓库。

    2019-05-27
    4
  • 业余草
    总结:OpenResty 的三大特性。
    1、详尽的文档和测试用例(这个不能算特性吧)。
    2、同步非阻塞。
    3、动态。
    2019-05-29
    3
  • FF
    请教下温老师,关于阻塞/非阻塞。

    如果 CPU 趁机去处理其他连接的请求,那就是非阻塞。

    但对于用户线程来讲,怎么理解这个非阻塞呢?

    理解1,这个查询的用户线程是不是还得阻塞等待 1 秒钟等待返回?这样的话应用的性能还是会不理想?

    理解2,用户线程也是非阻塞,操作系统线程非阻塞返回后,用户的数据不一定有,这个时候用户线程要轮询去调用查询,直到有数据。这样的话,对于应用来讲,性能不是一样不理想?

    哪种理解是对的呢?但无论哪种,用户应用性能可能都提不上理想,这样的话为何非阻塞是C10K,C100K 实现的关键呢?

    作者回复: 理解 1 是对的。站在用户请求的角度,非阻塞并不会减少处理的时间,但是会减少等待的时间。OpenResty 的每个 worker 同一时间只在处理一个请求,如果阻塞了,这个 worker 上的其他请求都需要等待。
    C10K 要解决的是高并发的问题,是服务端的整体性能。

    2019-05-27
    2
  • 馬偉偉💫
    期待已久,第一次听说这技术就是在网易云课堂老师讲的课,买了书准备学习老师就开了极客时间的专栏,结合书集和老师的专栏希望能有所收获。

    作者回复: 一起学习

    2019-05-27
    2
  • Guyun
    嘿嘿
    2019-07-04
    1
  • Luciano李鑫
    pr是啥意思

    作者回复: 是 GitHub 中 Pull Request 的缩写

    2019-06-04
    1
  • shonm
    老师你好,上面的代码中,如果是非阻塞的,他不是立马返回吗,怎么又会等1秒,怎么做到同步呢?

    作者回复: 非阻塞的自然不会等待 1 秒,但这 1 秒钟的时间内,CPU 是去处理其他请求的逻辑,并且把当前请求挂起。
    等数据库返回了结果后,才唤醒之前的请求,这样就做到了同步。

    2019-06-02
    2
    1
  • 许多子
    请问openresty可不可以就当作nginx来使用呢?不写lua的情况下,用来搭建web服务器,这两者有没有区别呢?

    作者回复: 当然可以,OpenResty 是基于 NGINX 的。但需要注意的是,OpenResty 的版本一般会落后于 NGINX。

    2019-05-28
    1
  • smartyoung
    不要通过类比去理解同步非阻塞,从这句话就感觉老师很务实,网上很多举例子的真的特别误导人,尤其一些没实际经验的新手,还是要从概念入手,多多体会,才能领会精髓。
    2019-05-28
    1
  • 小刚
    代码实现是同步与异步,阻塞是线程调用过程
    2019-05-27
    1
  • 叫我图图就可以了
    又一个角度
    2019-05-27
    1
  • Geek_67aae8
    做爬虫的话,怎么样?
    2019-12-11
  • ZeroIce
    老师,异步可否通过js 宏、微任务进行理解?即:单线程js想做多线程的事(例:settimeout),

    非阻塞:通过多线程进行并发处理

    作者回复: js 的不太懂

    2019-08-02
  • -W.LI-
    老师好!这个同步非阻塞和。IO模型的非阻塞一样么?同步响应成功失败,配合IO多路复用使用。主线程selector多路复用器阻塞,任务提交线程池处理(子线程)。子线程处理完以后通过调用channel的回调函数响应客户端?
    2019-07-28
  • .
    我对同步异步,阻塞非阻塞的理解是:把它们分别类比成‘’人‘’和’‘‘事’’。同步:一个人做事;异步;多个人同时做事。阻塞:要做的多件事情串行执行,做完一件事之后才能开始做下一件事;非阻塞:要做的多件事情互相穿插执行,无严格顺序要求。
    2019-06-20
  • 张智凯
    学了这门课程,还用看openresty入门到实践那本书吗

    作者回复: 没有了解过这本书,不好评价

    2019-06-06
  • 18210067841
    Lua到底怎么读?

    作者回复: 我读“路啦”

    2019-06-03
    1
  • 18210067841
    不懂就问:文中一直说的API网关是指什么?和nginx,tomcat,apache这种web服务器有什么区别?

    作者回复: API 网关是用来统一管理服务的网关,比如支付、用户登录等都是 API 形式对外提供的服务,它们都需要一个网关来做统一的安全和身份认证。
    API 网关是基于 web 服务器,或者在 web 服务器后面一层的。

    2019-06-03
收起评论
25
返回
顶部