openresty组成和技术特点

一、组成

openresty包含4个部分,

第一个部分lua-nginx-module,ngx的c module,将lua协程的唤醒和挂起纳入nginx事件驱动模块中,并提供丰富的lua api,使得开发者可以使用lua语言可以完成http层操作

第二个部分,测试集,对lua-ngx-module做全面测试,工作量,复杂度高

第三部分,resty库,lrucache,beanstalkd,redis

第四部分,在生产环境中,出现cpu过高,或者单个cpu占用率过低问题,工具集中包含丰富systemap脚本,可以打印当前情况下,ngx和lua函数cpu占用时间,或者内存占用量

二、技术特点

1、lua中揉合和处理各种不同的nginx上游输出,ssdb,drizzle,postgres,redis,memcached

2、或者在访问请求到达上有服务器前,lua可以随心所欲的做复杂的访问控制和安全检查,防止一些sql注入,xss攻击

3、在内容句柄中随意编写复杂的web应用,使用同步的编程方式,内部是异步非阻塞的执行过程,去访问数据库或其他存储

4、在rewrite阶段,通过lua完成非常复杂的URL dispatch

三、业务使用

总体为两类,将ngx作为入口,另一类将ngx作为web application。得益于lua的易用性,和c的高效性。这些控制的时间复杂的不会太高,但是执行效率又非常优秀,上述技术特点决定,openresty业务场景很广泛。但目前只在c端行业广泛应用,在电商,存储,游戏设计到。

发布了524 篇原创文章 · 获赞 172 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/INGNIGHT/article/details/104914491
今日推荐