一、Nginx概述
Nginx是一种高效能的HTTP服务器,以其卓越的性能而闻名。在极限情况下,一个单独的Tomcat服务器可能只能处理大约500个并发连接,这对于流量密集型的网站首页而言远远不够。因此,当面临高并发访问时,单一Tomcat服务器可能无法承受,导致服务崩溃。对于Tomcat集群而言,虽然可以扩展至5台服务器,但超过这个数量后,性能并不会有所提升,反而可能下降。
因此,在服务器的选择上,Nginx成为了一个理想的选择。理论上,一台Nginx服务器能够处理高达50000个并发连接,显示出其卓越的性能。Nginx不仅能够作为HTTP服务器,还能作为反向代理和负载均衡服务器使用。
作为负载均衡器,Nginx能够接收所有进入的请求并将它们分发到Tomcat集群中的各个服务器。作为反向代理,Nginx可以根据访问的URL地址将请求转发至特定的服务器处理。同时,Nginx作为HTTP服务器运行静态资源(如HTML、CSS、JS、图片等)的效率也远高于Tomcat。
二、OpenResty概览
1)OpenResty简介
OpenResty(也称为ngx_openresty)是一个基于Nginx的可扩展Web平台,由中国开发者章亦春创立,集成了众多高质量的第三方模块。作为一个强大的Web应用服务器,OpenResty允许Web开发者使用Lua脚本来调用Nginx支持的C和Lua模块,构建能够处理高达数万并发连接的高性能Web应用系统。OpenResty的核心目标是让Web服务器直接运行在Nginx内部,充分利用Nginx的非阻塞IO模型,对HTTP客户端请求以及远程后端服务(如MySQL、Redis、Memcache)提供一致的高性能响应。
包括360、UPYUN、阿里云、新浪、腾讯、去哪儿网、酷狗音乐在内的多家知名企业都是OpenResty的深度用户。
简而言之,OpenResty相当于对Nginx进行了封装,并集成了Lua脚本,使得开发者能够通过简单的模块调用实现所需逻辑,而无需自行编写和调用Lua脚本。
2)OpenResty安装
在Linux上安装OpenResty的步骤如下:
-
添加仓库并执行命令:
yum install yum-utils
yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo -
执行安装命令:
yum install openresty
安装完成后,默认安装目录为:
```
/usr/local/openresty
```
- 安装Nginx
OpenResty默认已包含Nginx,位于目录:/usr/local/openresty/nginx
下。修改/usr/local/openresty/nginx/conf/nginx.conf
,将配置文件的用户设置为root,以便未来直接在root目录下加载Lua脚本。
```
#user nobody; 原配置文件首行为这样,现更改为以下配置
user root root;
```
测试访问地址:http://192.168.200.128
三、Lua基础入门
Lua简介
Lua是一种轻量级的脚本语言,由巴西里约热内卢天主教大学的Roberto Ierusalimschy、Waldemar Celes和Luiz Henrique de Figueiredo三位研究人员于1993年开发。Lua的设计初衷是通过灵活嵌入应用程序中,为应用程序提供灵活的扩展和定制功能。Lua使用标准C语言编写,几乎可以在所有操作系统和平台上编译和运行。Lua并没有提供丰富的库,这是由其定位决定的,因此它不适合作为开发独立应用程序的语言。Lua有一个并行的JIT项目,提供特定平台上的即时编译功能。
简而言之,Lua是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放,其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。
Lua 语言特性
- 支持面向过程编程和函数式编程;
- 自动内存管理;提供一种通用类型的表(table),用以实现数组、哈希表、集合、对象;
- 语言内置模式匹配;闭包;函数也可以视为一个值;提供多线程(协同程序,非操作系统线程)支持;
- 通过闭包和table可以方便地支持面向对象编程所需的关键机制,如数据抽象、虚函数、继承和重载等。
Lua 应用场景
- 游戏开发;
- 独立应用脚本;
- Web应用脚本;
- 扩展和数据库插件,如MySQL Proxy和MySQL WorkBench;
- 安全系统,例如入侵检测系统;
- 在Redis中嵌套调用实现类似事务的功能;
- 在Web容器中应用处理过滤、缓存等逻辑,例如Nginx。
**Lua的安装