`
jinnianshilongnian
  • 浏览: 21513605 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2420447
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3010220
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5640568
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:260217
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1597925
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250368
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5860558
Group-logo
跟我学Nginx+Lua开...
浏览量:702867
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:785734
社区版块
存档分类
最新评论

第一章 安装OpenResty(Nginx+Lua)开发环境

阅读更多

首先我们选择使用OpenResty,其是由Nginx核心加很多第三方模块组成,其最大的亮点是默认集成了Lua开发环境,使得Nginx可以作为一个Web Server使用。借助于Nginx的事件驱动模型和非阻塞IO,可以实现高性能的Web应用程序。而且OpenResty提供了大量组件如Mysql、Redis、Memcached等等,使在Nginx上开发Web应用更方便更简单。目前在京东如实时价格、秒杀、动态服务、单品页、列表页等都在使用Nginx+Lua架构,其他公司如淘宝、去哪儿网等。

安装环境

安装步骤可以参考http://openresty.org/#Installation

 

1、创建目录/usr/servers,以后我们把所有软件安装在此目录

mkdir -p /usr/servers
cd /usr/servers/

 

2、安装依赖(我的环境是ubuntu,可以使用如下命令安装,其他的可以参考openresty安装步骤)

apt-get install libreadline-dev libncurses5-dev libpcre3-dev libssl-dev perl

 

3、下载ngx_openresty-1.7.7.2.tar.gz并解压

wget http://openresty.org/download/ngx_openresty-1.7.7.2.tar.gz
tar -xzvf ngx_openresty-1.7.7.2.tar.gz

 

ngx_openresty-1.7.7.2/bundle目录里存放着nginx核心和很多第三方模块,比如有我们需要的Lua和LuaJIT。

 

3、安装LuaJIT

cd bundle/LuaJIT-2.1-20150120/
make clean && make && make install
ln -sf luajit-2.1.0-alpha /usr/local/bin/luajit

 

4、下载ngx_cache_purge模块,该模块用于清理nginx缓存

cd /usr/servers/ngx_openresty-1.7.7.2/bundle
wget https://github.com/FRiCKLE/ngx_cache_purge/archive/2.3.tar.gz
tar -xvf 2.3.tar.gz

 

5、下载nginx_upstream_check_module模块,该模块用于ustream健康检查

cd /usr/servers/ngx_openresty-1.7.7.2/bundle
wget https://github.com/yaoweibin/nginx_upstream_check_module/archive/v0.3.0.tar.gz
tar -xvf v0.3.0.tar.gz 
  

6、安装ngx_openresty

cd /usr/servers/ngx_openresty-1.7.7.2
./configure --prefix=/usr/servers --with-http_realip_module  --with-pcre  --with-luajit --add-module=./bundle/ngx_cache_purge-2.3/ --add-module=./bundle/nginx_upstream_check_module-0.3.0/ -j2
make && make install

 

--with***                安装一些内置/集成的模块

--with-http_realip_module  取用户真实ip模块

-with-pcre               Perl兼容的达式模块

--with-luajit              集成luajit模块

 

--add-module            添加自定义的第三方模块,如此次的ngx_che_purge

 

8、到/usr/servers目录下 

cd /usr/servers/
ll 

 

会发现多出来了如下目录,说明安装成功

/usr/servers/luajit :luajit环境,luajit类似于java的jit,即即时编译,lua是一种解释语言,通过luajit可以即时编译lua代码到机器代码,得到很好的性能;

/usr/servers/lualib:要使用的lua库,里边提供了一些默认的lua库,如redis,json库等,也可以把一些自己开发的或第三方的放在这;

/usr/servers/nginx :安装的nginx;

 

通过/usr/servers/nginx/sbin/nginx  -V 查看nginx版本和安装的模块

 

7、启动nginx

/usr/servers/nginx/sbin/nginx

 

接下来该配置nginx+lua开发环境了

 

配置环境

配置及Nginx HttpLuaModule文档在可以查看http://wiki.nginx.org/HttpLuaModule

 

 

1、编辑nginx.conf配置文件 

vim /usr/servers/nginx/conf/nginx.conf

  

2、在http部分添加如下配置 

#lua模块路径,多个之间”;”分隔,其中”;;”表示默认搜索路径,默认到/usr/servers/nginx下找
lua_package_path "/usr/servers/lualib/?.lua;;";  #lua 模块
lua_package_cpath "/usr/servers/lualib/?.so;;";  #c模块 

  

3、为了方便开发我们在/usr/servers/nginx/conf目录下创建一个lua.conf 

#lua.conf
server {
    listen       80;
    server_name  _;
}

 

4、在nginx.conf中的http部分添加include lua.conf包含此文件片段 

include lua.conf;

  

5、测试是否正常 

/usr/servers/nginx/sbin/nginx  -t 

 

如果显示如下内容说明配置成功

nginx: the configuration file /usr/servers/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/servers/nginx/conf/nginx.conf test is successful

 

HelloWorld

1、在lua.conf中server部分添加如下配置 

location /lua {
    default_type 'text/html';
        content_by_lua 'ngx.say("hello world")';
}

         

2、测试配置是否正确 

/usr/servers/nginx/sbin/nginx  -t

   

3、重启nginx 

/usr/servers/nginx/sbin/nginx  -s reload

 

 4、访问如http://192.168.1.6/lua(自己的机器根据实际情况换ip),可以看到如下内容 

hello world

 

5、lua代码文件

我们把lua代码放在nginx配置中会随着lua的代码的增加导致配置文件太长不好维护,因此我们应该把lua代码移到外部文件中存储。 

vim /usr/servers/nginx/conf/lua/test.lua
#添加如下内容
ngx.say("hello world"); 

 

然后lua.conf修改为   

    location /lua {
        default_type 'text/html';
        content_by_lua_file conf/lua/test.lua; #相对于nginx安装目录
    } 

此处conf/lua/test.lua也可以使用绝对路径/usr/servers/nginx/conf/lua/test.lua。

 

6、lua_code_cache 

默认情况下lua_code_cache  是开启的,即缓存lua代码,即每次lua代码变更必须reload nginx才生效,如果在开发阶段可以通过lua_code_cache  off;关闭缓存,这样调试时每次修改lua代码不需要reload nginx;但是正式环境一定记得开启缓存。 

    location /lua {
        default_type 'text/html';
        lua_code_cache off;
        content_by_lua_file conf/lua/test.lua;
}

 

开启后reload nginx会看到如下报警

nginx: [alert] lua_code_cache is off; this will hurt performance in /usr/servers/nginx/conf/lua.conf:8

 

7、错误日志

 

如果运行过程中出现错误,请不要忘记查看错误日志。 

tail -f /usr/servers/nginx/logs/error.log

 

到此我们的基本环境搭建完毕。

 

nginx+lua项目构建

以后我们的nginx lua开发文件会越来越多,我们应该把其项目化,已方便开发。项目目录结构如下所示:

example

    example.conf     ---该项目的nginx 配置文件

    lua              ---我们自己的lua代码

      test.lua

    lualib            ---lua依赖库/第三方依赖

      *.lua

      *.so

 

其中我们把lualib也放到项目中的好处就是以后部署的时候可以一起部署,防止有的服务器忘记复制依赖而造成缺少依赖的情况。

 

我们将项目放到到/usr/example目录下。

 

/usr/servers/nginx/conf/nginx.conf配置文件如下(此处我们最小化了配置文件)

#user  nobody;
worker_processes  2;
error_log  logs/error.log;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  text/html;

    #lua模块路径,其中”;;”表示默认搜索路径,默认到/usr/servers/nginx下找
    lua_package_path "/usr/example/lualib/?.lua;;";  #lua 模块
    lua_package_cpath "/usr/example/lualib/?.so;;";  #c模块
    include /usr/example/example.conf;
}

通过绝对路径包含我们的lua依赖库和nginx项目配置文件。

 

/usr/example/example.conf配置文件如下 

server {
    listen       80;
    server_name  _;

    location /lua {
        default_type 'text/html';
        lua_code_cache off;
        content_by_lua_file /usr/example/lua/test.lua;
    }
}

lua文件我们使用绝对路径/usr/example/lua/test.lua。 

 

到此我们就可以把example扔svn上了。

 

25
0
分享到:
评论
13 楼 anyzm311 2018-01-18  
发现一个问题,请教下:
我在access_by_lua_file和init_by_lua_file两个节点分别进行require加载自己写的一个东西,在init_by_lua_file中require后面使用没有任何问题,但在access_by_lua_file中require时,发现只有第一次调用有效,后面调用时为nil.该类的代码如下:

local TrafficControlManager = {}

TrafficControlManager.f = nil;

function TrafficControlManager:new(o) 
    o = o or {} 
    setmetatable(o,self) 
    self.__index = self
    return o 
end 
 
function TrafficControlManager:GetInstance() 
    if self.instance == nil then 
        self.instance = self:new()
    end 
    return self.instance 
end 

--全局限流,参数为限流值
function TrafficControlManager:gloalTraffic(gloalMax)
    return false
end



请帮忙说下,这是什么问题,我自己理解是lua在init_by_lua_file中require时,会是整个nginx生命周期,在access_by_lua_file中require时,生命周期限本次访问,第二次访问时,因为require已经执行过了,所以没有再加载,而己加载的又失效了,不知道是不是这样,望解答,谢谢。
12 楼 Tro_picana 2017-08-01  
开涛老师:
基于ngx_cache_purge 针对目录删除缓存目前有现成的模块可以用吗?
11 楼 solid210 2017-06-02  
578936807 写道
开涛,我把lua.conf里的配置改成目录访问形式后,如下:
  content_by_lua_file /conf/lua/test.lua
浏览器访问就一直报404,但是用content_by_lua 'ngx.say("hello")'访问就正常。哪里的问题?求解答。

404错误是因为你的路径有问题, 如果使用绝对路径, 注意检查路径是否正确, 并且下面有没有你所指定的lua文件.
10 楼 578936807 2017-04-27  
开涛,我把lua.conf里的配置改成目录访问形式后,如下:
  content_by_lua_file /conf/lua/test.lua
浏览器访问就一直报404,但是用content_by_lua 'ngx.say("hello")'访问就正常。哪里的问题?求解答。
9 楼 Godparent 2016-08-25  
8 楼 andy_gaoxu 2015-12-25  
开涛,你好:问你一个问题,你们的redis集群现在是2.x的版本吧,你们有准备升级成3.0的打算吗?
7 楼 nonobaba 2015-05-22  
jinnianshilongnian 写道
nonobaba 写道
local a = {};
a[0]=11111;
a[1]=10;
a[2]=11;
a[5]=1231;
a["nimei"]=12312;

for key=1, #(a)
    do print(key);
end

这个按说应该打印
1
2
的,不过却打印出了
1
2
3
4
5
这个是lua的bug吗?

不是的, a["nimei"] 这种的需要 in pairs()


今天找到原因了,因为我使用的sdk是luaj和实际的lua有出入,我把sdk改为5.3版的lua就行了。
6 楼 jinnianshilongnian 2015-05-22  
nonobaba 写道
local a = {};
a[0]=11111;
a[1]=10;
a[2]=11;
a[5]=1231;
a["nimei"]=12312;

for key=1, #(a)
    do print(key);
end

这个按说应该打印
1
2
的,不过却打印出了
1
2
3
4
5
这个是lua的bug吗?

不是的, a["nimei"] 这种的需要 in pairs()
5 楼 nonobaba 2015-05-21  
local a = {};
a[0]=11111;
a[1]=10;
a[2]=11;
a[5]=1231;
a["nimei"]=12312;

for key=1, #(a)
    do print(key);
end

这个按说应该打印
1
2
的,不过却打印出了
1
2
3
4
5
这个是lua的bug吗?
4 楼 nonobaba 2015-05-21  
jinnianshilongnian 写道
nonobaba 写道
lua开发调试如何调试,我看了官方网站的openresty的debugging部分没看明白,感觉没看开发工具的调试结合起来, 如果有类似eclipse调试tomcat上的应用的工具就好了,请问开涛大神平时是怎么开发调试的?

我们就是手写代码 哈哈

大神都是这样的吗?
3 楼 jinnianshilongnian 2015-05-21  
nonobaba 写道
lua开发调试如何调试,我看了官方网站的openresty的debugging部分没看明白,感觉没看开发工具的调试结合起来, 如果有类似eclipse调试tomcat上的应用的工具就好了,请问开涛大神平时是怎么开发调试的?

我们就是手写代码 哈哈
2 楼 nonobaba 2015-05-21  
lua开发调试如何调试,我看了官方网站的openresty的debugging部分没看明白,感觉没看开发工具的调试结合起来, 如果有类似eclipse调试tomcat上的应用的工具就好了,请问开涛大神平时是怎么开发调试的?
1 楼 somefuture 2015-03-20  
能不能说一下为什么要选择这种架构,和其他同类框架比起来,lua能快多少,其他优势是什么等等。

相关推荐

    nginx+lua+redis 集群 连接插件和脚本

    本资源包“nginx+lua+redis集群 连接插件和脚本”正是为了解决这三者之间的协同工作,特别是针对原插件没有密码功能的问题进行了改进,使得安全性得到了提升。 首先,Nginx是一款轻量级的Web服务器/反向代理服务器...

    idea openrestry+nginx+lua搭建企业级开发环境

    "Idea OpenResty + Nginx + Lua" 的组合提供了一种强大的解决方案,它允许开发者利用 IntelliJ IDEA(Idea)作为集成开发环境,OpenResty(一个扩展了 Nginx 的版本)作为服务器平台,以及 Lua 语言进行高性能的脚本...

    nginx+lua+redis实现token验证

    总的来说,`nginx+lua+redis`的组合提供了一种高效、灵活的方式来实现`token`验证和其他安全措施。这种架构使得我们可以快速响应变化,同时保持服务的高性能和稳定性。通过深入理解和熟练运用这些工具,开发者可以...

    跟我学Nginx+Lua开发

    做完第一步的安装和测试示例的编写,lua+nginx就表示已经集成成功,接下来就是自己业务逻辑的开发。在这里需要注意的是因为openresty其实也是集成了nginx,所以在一台机器上跑两个nginx可能有相应的问题,所以在安装...

    Nginx+lua通过url传参的方式实现动态代理

    - **OpenResty**:是一个基于Nginx与Lua的高性能Web平台,它极大地简化了在Nginx上编写复杂的Web应用的过程。OpenResty提供了强大的Lua API,可以用来处理HTTP请求和响应,实现复杂的功能逻辑。 #### 需求分析 本...

    Nginx+upload+lua实现简单文件上传服务

    安装OpenResty,并在Nginx配置中启用lua模块。 4. **编写lua脚本** 创建一个处理文件上传的lua脚本,例如`upload_handler.lua`,这个脚本会接收Nginx传递的文件信息,并进行处理,如保存文件、验证文件大小和类型...

    跟我学Nginx + Lua开发

    安装Nginx+Lua开发环境首先需要创建一个目录用于存放所有软件。之后,需要安装一些依赖,例如libreadline-dev、libncurses5-dev、libpcre3-dev、libssl-dev、perl等。接着,下载并解压OpenResty的源码包,执行...

    京东李开涛 跟我学Nginx+Lua 开发

    通过以上知识点的介绍,我们可以了解到Nginx+Lua+OpenResty这一组合在Web高并发场景下的强大能力。不仅能够有效地解决大规模并发访问带来的挑战,还能在提高用户体验的同时降低运营成本。对于任何希望构建高性能Web...

    跟我学Nginx+Lua开发.pdf

    #### 一、Nginx+Lua开发环境简介 《跟我学Nginx+Lua开发》是一本针对Nginx与Lua结合使用的教程书籍,旨在帮助读者理解如何利用这两种技术进行高效且灵活的Web应用开发。Nginx作为一款广泛使用的高性能HTTP服务器和...

    2 OpenResty+Lua+Redis 高性能后端接口.docx

    OpenResty+Lua+Redis 高性能后端接口 OpenResty 是基于 Nginx 的高性能 web 服务器,它使用 Lua 语言作为脚本语言来实现动态内容生成和处理。 Lua 是一种轻量级的脚本语言,广泛应用于游戏、嵌入式系统和 web 开发...

    idea+openresty+lua运行nginx服务器.zip

    idea+openresty+lua运行nginx服务器, 代码和软件都有, 参考资料: https://blog.csdn.net/dongyuxu342719/article/details/90413904

    Nginx+Lua阿⾥实战经验谈.pdf

    Nginx+Lua的起源可以追溯到淘宝时期,由创始人王晓哲和章亦春推动,最初在量子统计项目中得到应用。随着OpenResty的创立,ngx_lua模块被引入全球社区,获得了广泛的认可。这一技术逐渐替代了部分Java中间件的功能,...

    基于nginx+lua+dyups实现服务自定义调度资源整理

    在构建高性能和灵活的服务调度系统时,`nginx`作为一个强大的反向代理和负载均衡器,常常被用来处理复杂的网络流量管理。结合`lua`脚本语言以及特定的模块,如`dyups`,可以实现自定义的服务调度策略。本文将详细...

    nginx+lua简要说明

    而目前市面上用的非常成熟的扩展是由章亦春将Lua和Nginx粘合的ngx_lua模块,并且将Nginx核心、LuaJIT、ngx_lua模块、许多有用的Lua库和常用的第三方Nginx模块组合在一起成为OpenResty,这样开发人员就可以安装...

    Nginx+lua+OpenResty高性能实践

    Nginx+lua+OpenResty高性能实践 高性能 处理高并发能力上很强 高扩展性 Nginx模块化,官方提供了多元化的模块。 高可用性 三个9 99.9% 四个9 99.99% 热部署(版本平滑升级) 服务进行升级的同时,保证业务 不宕机 ...

Global site tag (gtag.js) - Google Analytics