OpenResty(也称为 ngx_openresty)是一个全功能的 Web 应用服务器。它打包了标准的 Nginx 核心,很多的常用的第三方模块,以及它们的大多数依赖项。
通过揉和众多设计良好的 Nginx 模块,OpenResty 有效地把 Nginx 服务器转变为一个强大的 Web 应用服务器,基于它开发人员可以使用 Lua 编程语言对 Nginx 核心以及现有的各种 Nginx C 模块进行脚本编程,构建出可以处理一万以上并发请求的极端高性能的 Web 应用。

OpenResty 致力于将你的服务器端应用完全运行于 Nginx 服务器中,充分利用 Nginx 的事件模型来进行非阻塞 I/O 通信。不仅仅是和 HTTP 客户端间的网络通信是非阻塞的,与MySQL、PostgreSQL、Memcached 以及 Redis 等众多远方后端之间的网络通信也是非阻塞的。
因为 OpenResty 软件包的维护者也是其中打包的许多 Nginx 模块的作者,所以 OpenResty 可以确保所包含的所有组件可以可靠地协同工作。

OpenResty 最早是雅虎中国的一个公司项目,起步于 2007 年 10 月。当时兴起了 OpenAPI 的热潮,用于满足各种 Web Service 的需求,就诞生了 OpenResty。在公司领导的支持下,最早的 OpenResty 实现从一开始就开源了。最初的定位是服务于公司外的开发者,像其他的 OpenAPI 那样,但后来越来越多地是为雅虎中国的搜索产品提供内部服务。这是第一代的 OpenResty,当时的想法是,提供一套抽象的 web service,能够让用户利用这些 web service 构造出新的符合他们具体业务需求的 Web Service 出来,所以有些“meta web servie”的意味,包括数据模型、查询、安全策略都可以通过这种 meta web service 来表达和配置。同时这种 web service 也有意保持 REST 风格。与这种概念相对应的是纯 AJAX 的 web 应用,即 web 应用几乎都使用客户端 JavaScript 来编写,然后完全由 web service 让 web 应用“活”起来。用户把 .html, .js, .css, .jpg 等静态文件下载到 web browser 中,然后 js 开始运行,跨域请求雅虎提供的经过站长定制过的 web service,然后应用就可以运行起来。不过随着后来的发展,公司外的用户毕竟还是少数,于是应用的重点是为公司内部的其他团队提供 web service,比如雅虎中国的全能搜索产品,及其外围的一些产品。从那以后,开发的重点便放在了性能优化上面。章亦春在加入淘宝数据部门的量子团队之后,决定对 OpenResty 进行重新设计和彻底重写,并把应用重点放在支持像量子统计这样的 web 产品上面,所以量子统计 3.0 开始也几乎完全是 web service 驱动的纯 AJAX 应用。
这是第二代的 OpenResty,一般称之为 ngx_openresty,以便和第一代基于 Perl 和 Haskell 实现的 OpenResty 加以区别。章亦春和他的同事王晓哲一起设计了第二代的 OpenResty。在王晓哲的提议下,选择基于 nginx 和 lua 进行开发。
为什么要取 OpenResty 这个名字呢?OpenResty 最早是顺应 OpenAPI 的潮流做的,所以 Open 取自“开放”之意,而Resty便是 REST 风格的意思。虽然后来也可以基于 ngx_openresty 实现任何形式的 web service 或者传统的 web 应用。
也就是说 Nginx 不再是一个简单的静态网页服务器,也不再是一个简单的反向代理了。第二代的 openresty 致力于通过一系列 nginx 模块,把nginx扩展为全功能的 web 应用服务器。
ngx_openresty 是用户驱动的项目,后来也有不少国内用户的参与,从 openresty.org 的点击量分布上看,国内和国外的点击量基本持平。

ngx_openresty 目前有两大应用目标:

  1. 通用目的的 web 应用服务器。在这个目标下,现有的 web 应用技术都可以算是和 OpenResty 或多或少有些类似,比如 Nodejs, PHP 等等。ngx_openresty 的性能(包括内存使用和 CPU 效率)算是最大的卖点之一。
  2. Nginx 的脚本扩展编程,用于构建灵活的 Web 应用网关和 Web 应用防火墙。有些类似的是 NetScaler。其优势在于 Lua 编程带来的巨大灵活性。

ngx_openresty 从一开始就是公司实际的业务需求的产物。在过去的几年中的大部分开发工作也是由国内外许多公司和个人的实际业务需求驱动的。这种模型在实践中工作得非常好,可以确保我们做的就是大家最迫切需要的。在此过程中,慢慢形成了 ngx_openresty 的两大应用方向,也就是前面提到的那两大方向。是我们的用户帮助我们确认了这两个方向,事实上,这并不等同于第一代 OpenResty 的方向,而是变得更加底层和更加通用了。

开源精神的核心是分享而非追求流行。毕竟开源界不是娱乐圈,也不是时尚圈。如果我们的开源项目有越来越多的人开始使用,只是一个“happy accident”,我们自然会很高兴,但这并不是我们真正追求的。

开放源码只是开源项目生命周期中的“万里长征第一步”,国内的许多开源项目止步于开放源码,而没有后续投入长期的时间和精力去跟进响应用户的各种需求和反馈,但不免夭折。这种现象在国外的不少开源项目中也很常见。

国外成功的开源项目比较多,或许跟许多发达国家的程序员们的精神状态有关系。比如我认识的一些国外的黑客都非常心思单纯,热情似火。他们在精神上的束缚非常少,做起事来多是不拘一格。有的人即便长期没有工作单纯靠抵押和捐赠过活,也会不遗余力地投身于开源项目。而我接触到的国内许多程序员的精神负担一般比较重,经济上的压力也比较大,自然难有“玩开源”的心思。

不过,国内也是有一些程序员拥有国外优秀黑客的素质的,而且他们通过网络和全球的黑客紧密联系在一起,所以我们完全可以期待他们未来有振奋人心的产出。在互联网时代的今天,或许按国界的划分来讨论这样的问题会变得越来越不合时宜。

转载于:https://www.cnblogs.com/sunhongleibibi/p/9190598.html

OpenResty简介相关推荐

  1. OpenResty简介及学习笔记

    OpenResty简介及学习笔记 摘要 简介 一.OpenResty综述 二.指令说明: *_by_lua *_by_lua_block {lua_script} *_by_lua_file 三.登陆 ...

  2. 基于OpenResty的弹性网关实践(一)

    一.介绍 1. OpenResty简介 官方地址:http://openresty.org/cn/ github地址:https://github.com/openresty/ OpenResty最佳 ...

  3. Openresty实现web应用防火墙(waf)

    Openresty简介 OpenResty 是由中国人章亦春发起,把nginx和各种三方模块的一个打包而成的软件平台,核心就是nginx+lua脚本语言.主要是因为nginx是C语言编写,修改很复杂, ...

  4. lnmp架构之使用openresty构建memc+srcache

    一.OpenResty简介 OpenResty官网    http://openresty.org/cn/ OpenResty是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大 ...

  5. OpenResty入门教程

    1.OpenResty简介 2.OpenResty的安装(联网,这里我在Centos7中安装) 1)安装OpenResty的依赖开发库 yum install -y pcre-devel openss ...

  6. openresty服务器

    一.OpenResty简介 OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web 平台,由中国人章亦春发起,提供了很多高质量的第三方模块. OpenRes ...

  7. openresty 概述

    openresty 概述 官网:http://openresty.org/cn/ openresty 简介 openresty基于nginx.lua的web平台,整合了大量三方模块,可直接使用,不需要 ...

  8. 解秘亿级网站的一本书——亿级流量网站架构核心技术

    网站是直接面对广大客户的,是公司的门户,必须快速响应,必须持续可用,必须抗得住洪峰.任何一个网站的发展过程中都出现过问题,影响客户体验和商业利益,公司业务规模越大,网站出现问题的损失越大.此时此刻,有 ...

  9. 读书笔记: 《亿级流量网站架构核心技术》(开涛的那本)

    这本书知识范围广,但都浅尝辄止,可以用来开阔视野,由于之前看过李智慧的<大型网站技术架构>,有部分内容是重合的,所以翻起来比较快.这里只记录下之前没太了解的点 第1章:交易型系统设计的一些 ...

最新文章

  1. 博为峰JavaEE技术文章 —— Hibernate 指南(3)Hbm文件
  2. 图像修复中的方法--AI智能.
  3. 九度OJ-1042-最长公共子序列(LCS)
  4. 建议收藏!百度不到的硬核资源~
  5. Python基础教程---读书笔记四
  6. 10.27模拟 总结
  7. Jmeter常用插件——梯度加压、响应时间、TPS_老版本
  8. 使用百度云智能SDK和树莓派搭建简易的人脸识别系统 Python语言版
  9. bzoj4330:JSOI2012 爱之项链
  10. 康奈尔机器人的肌肉是爆米花做的,果然很有爆发力 | ICRA 2018
  11. python课程-Python课程学习总结
  12. C语言实现九九乘法表(四种情况)
  13. OpenvSwitch实现简单VLAN
  14. 小学生作业打印推荐哪个软件?
  15. layui文档,最新文档地址,官网已经下线
  16. 小米盒子服务器无信号,小米小盒子连接HDMI无信号怎么办?
  17. mac关于 E45: ‘readonly‘ option is set (add ! to override)
  18. Ubuntu下vscode配置OpenGL(使用glfw+glad)
  19. redis缓存与数据库一致性问题解决
  20. 用彩信模块发图片问题总结(STM32)

热门文章

  1. Shell echo-使用echo实现更复杂的输出格式控制
  2. oracle日期相减工作日_Oracle 计算两个日期间隔的天数、月数和年数
  3. java面试题oracle,2021年度javasqloracle面试题汇总.doc
  4. 绅士计算机乐谱之谦,绅士(简单钢琴独奏版)
  5. i2c Linux 动态 波特率,如何在Linux中设置i2c总线的波特率?
  6. linux备份sqlserver数据库,Linux sqlServer数据库还原办法
  7. 全阶滑模观测器程序_基于全阶状态滑模观测器的异步电机转子磁链观测_杨淑英...
  8. 17原理图查找连接的管脚接口_第三节 主板原理图之标识的作用
  9. Machine Learning - Andrew Ng on Coursera (Week 5)
  10. Caffe学习系列(18): 绘制网络模型