• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

使用openresty+lua搭建api网关(一)安装openresty,并添加lua模块

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

openresty 有点不多说,网上各种介绍,先安装吧。

官方操作在此,http://openresty.org/cn/installation.html

tar -xzvf openresty-VERSION.tar.gz
cd openresty-VERSION/
./configure
make
sudo make install

./configure

然后在进入 openresty-VERSION/ 目录, 然后输入以下命令配置:

./configure

默认, --prefix=/usr/local/openresty 程序会被安装到/usr/local/openresty目录。

您可以指定各种选项,比如

./configure --prefix=/opt/openresty \
            --with-luajit \
            --without-http_redis2_module \
            --with-http_iconv_module \
            --with-http_postgres_module

试着使用 ./configure --help 查看更多的选项。

Prepare directory layout

We first create a separate directory for our experiments. You can use an arbitrary directory. Here for simplicity, we just use ~/work:

mkdir ~/work
cd ~/work
mkdir logs/ conf/

Note that we've also created the logs/ directory for logging files and conf/ for our config files.

Prepare the nginx.conf config file

Create a simple plain text file named conf/nginx.conf with the following contents in it:

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {
    server {
        listen 8080;
        location / {
            default_type text/html;
            content_by_lua '
                ngx.say("<p>hello, world</p>")
            ';
        }
    }
}

If you're familiar with Nginx configuration, it should look very familiar to you. OpenResty is just an enhanced version of Nginx by means of addon modules anyway. You can take advantage of all the exisitng goodies in the Nginx world.

Nginx server

Assuming you have installed OpenResty into /usr/local/openresty (this is the default), we make our nginx executable of our OpenResty installation available in our PATH environment:

PATH=/usr/local/openresty/nginx/sbin:$PATH
export PATH

Then we start the nginx server with our config file this way:

nginx -p `pwd`/ -c conf/nginx.conf

Error messages will go to the stderr device or the default error log files logs/error.log in the current working directory.

Access our HelloWorld web service

We can use curl to access our new web service that says HelloWorld:

curl http://localhost:8080/

If everything is okay, we should get the output

<p>hello, world</p>

You can surely point your favorite web browser to the location http://localhost:8080/.

Test performance

See Benchmark for details.

Where to go from here

View the documentation of each component at the Components page and find Nginx related stuff on the Nginx Wiki site.

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

Java代码  
  1. mkdir -p /usr/servers  
  2. cd /usr/servers/  

 

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

Java代码  
  1. apt-get install libreadline-dev libncurses5-dev libpcre3-dev libssl-dev perl  

 

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

Java代码  
  1. wget http://openresty.org/download/ngx_openresty-1.7.7.2.tar.gz  
  2. tar -xzvf ngx_openresty-1.7.7.2.tar.gz  

 

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

 

3、安装LuaJIT

Java代码  
  1. cd bundle/LuaJIT-2.1-20150120/  
  2. make clean && make && make install  
  3. ln -sf luajit-2.1.0-alpha /usr/local/bin/luajit  

 

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

Java代码  
  1. cd /usr/servers/ngx_openresty-1.7.7.2/bundle  
  2. wget https://github.com/FRiCKLE/ngx_cache_purge/archive/2.3.tar.gz  
  3. tar -xvf 2.3.tar.gz  

 

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

Java代码  
  1. cd /usr/servers/ngx_openresty-1.7.7.2/bundle  
  2. wget https://github.com/yaoweibin/nginx_upstream_check_module/archive/v0.3.0.tar.gz  
  3. tar -xvf v0.3.0.tar.gz   

  

6、安装ngx_openresty

Java代码  
  1. cd /usr/servers/ngx_openresty-1.7.7.2  
  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  
  3. make && make install  

 

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

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

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

--with-luajit              集成luajit模块

 

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

 

8、到/usr/servers目录下 

Java代码  
  1. cd /usr/servers/  
  2. 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配置文件 

Java代码  
  1. vim /usr/servers/nginx/conf/nginx.conf  

  

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

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

  

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

Java代码  
  1. #lua.conf  
  2. server {  
  3.     listen       80;  
  4.     server_name  _;  
  5. }  

 

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

Java代码  
  1. include lua.conf;  

  

5、测试是否正常 

Java代码  
  1. /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部分添加如下配置 

Java代码  
  1. location /lua {  
  2.     default_type 'text/html';  
  3.         content_by_lua 'ngx.say("hello world")';  
  4. }  

         

2、测试配置是否正确 

Java代码  
  1. /usr/servers/nginx/sbin/nginx  -t  

   

3、重启nginx 

Java代码  
  1. /usr/servers/nginx/sbin/nginx  -s reload  

 

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

hello world

 

5、lua代码文件

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

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

 

然后lua.conf修改为   

Java代码  
  1. location /lua {  
  2.     default_type 'text/html';  
  3.     content_by_lua_file conf/lua/test.lua; #相对于nginx安装目录  
  4. }   

此处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;但是正式环境一定记得开启缓存。 

Java代码  
  1.     location /lua {  
  2.         default_type 'text/html';  
  3.         lua_code_cache off;  
  4.         content_by_lua_file conf/lua/test.lua;  
  5. }  

 

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

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

 

7、错误日志

 

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

Java代码  
  1. 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配置文件如下(此处我们最小化了配置文件)

Java代码  
  1. #user  nobody;  
  2. worker_processes  2;  
  3. error_log  logs/error.log;  
  4. events {  
  5.     worker_connections  1024;  
  6. }  
  7. http {  
  8.     include       mime.types;  
  9.     default_type  text/html;  
  10.   
  11.     #lua模块路径,其中”;;”表示默认搜索路径,默认到/usr/servers/nginx下找  
  12.     lua_package_path "/usr/example/lualib/?.lua;;";  #lua 模块  
  13.     lua_package_cpath "/usr/example/lualib/?.so;;";  #c模块  
  14.     include /usr/example/example.conf;  
  15. }  

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

 

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

Java代码  
  1. server {  
  2.     listen       80;  
  3.     server_name  _;  
  4.   
  5.     location /lua {  
  6.         default_type 'text/html';  
  7.         lua_code_cache off;  
  8.         content_by_lua_file /usr/example/lua/test.lua;  
  9.     }  
  10. }  

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

 

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
让Lua访问数据库发布时间:2022-07-22
下一篇:
lua——牛牛牌型处理相关算法(上)——牌值数据发布时间:2022-07-22
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap