文档章节

安装nginx_lua_module以及echo-nginx-module收集日志

闪电
 闪电
发布于 2016/12/16 01:00
字数 1318
阅读 203
收藏 2

unknown directive "access_by_lua" 

unknown directive "set_unescape_uri"

 

之所以报错是缺少nginx的三方插件,下面介绍安装nginx的第三方插件,插件很多直介绍三个

 

方式一:

 

下载 ngx_openresty,该集成包中有:NginxLuaLuajitngx_lua,以及一些有用的Nginx第三方模块。

安装步骤:

 

  1. ./configure --with-luajit   
  2. make   
  3. make install  

 

安装完成,个人建议第一种安装方便简单,另外这个版本还提供了很多的组件,安装不会出现错误。

 

方式二:

 

Ngx_lua手动编译进Nginx。
首先,我的 Nginx 安装路径为:/usr/local/nginx。

我将尝试编译的两个模块:echo,lua。
所需要的模块如下:
    liujit             http://luajit.org  
    lua                http://www.lua.org  
    ngx_devel_kit      https://github.com/simpl/ngx_devel_kit  
    echo-nginx-module  https://github.com/agentzh/echo-nginx-module  
    lua-nginx-module   https://github.com/chaoslawful/lua-nginx-module  

安装步骤:

1、Luajit2.0.2(推荐)

 

Java代码 

 收藏代码

  1. wget http://luajit.org/download/LuaJIT-2.0.2.tar.gz  
  2. tar zxvf LuaJIT-2.0.2.tar.gz  
  3. cd LuaJIT-2.0.2   
  4. make    
  5. sudo make install  

 

安装lua

 

tar-zxvf lua-5.2.0.tar.gz
cd lua-5.2.0
make linux
make install
完成安装.

如果遇到

lua.c:67:31: fatal error: readline/readline.h: No such file or directory
说明缺少libreadline-dev依赖包

centos: yum install readline-devel
debian: apt-get install libreadline-dev.

 


下面需要配置一下 luajit 或 lua 的环境变量(Nginx编译时需要):
 

Java代码 

 收藏代码

  1. -- luajit --   
  2. # tell nginx's build system where to find LuaJIT:   
  3. export LUAJIT_LIB=/path/to/luajit/lib   
  4. export LUAJIT_INC=/path/to/luajit/include/luajit-2.0.2  
  5. -- lua --   
  6. # or tell where to find Lua if using Lua instead:   
  7. export LUA_LIB=/path/to/lua/lib   
  8. export LUA_INC=/path/to/lua/include   

 

我的测试环境里,配置如下:
 

Java代码 

 收藏代码

  1. export LUAJIT_LIB=/usr/local/luajit/lib   
  2. export LUAJIT_INC=/usr/local/luajit/include/luajit-2.0  

   


2、安装 ngx_devel_kit (NDK) 模块

Java代码 

 收藏代码

  1. cd /usr/local   
  2. git clone https://github.com/simpl/ngx_devel_kit.git    

 

下载完成后,将在 /usr/local/ 目录下生成子目录 ngx_devel_kit。


3、安装 lua-nginx-module 模块

 

Java代码 

 收藏代码

  1. cd /usr/local   
  2. git clone https://github.com/chaoslawful/lua-nginx-module.git  

 

下载完成后,将在 /usr/local/ 目录下生成子目录 lua-nginx-module。


4、重新编译Nginx,需要注意编译顺序!

Java代码 

 收藏代码

  1. ./configure --prefix=/usr/local/nginx \   
  2.                 --with-ld-opt="-Wl,-rpath,$LUAJIT_LIB" \   
  3.                 --add-module=/usr/local/ngx_devel_kit \   
  4.                 --add-module=/usr/local/echo-nginx-module \   
  5.                 --add-module=/usr/local/lua-nginx-module   
  6. make -j2   
  7. make install   

  


注释:重新编译 Nginx 二进制,Nginx 需要 quit 再启动。而普通配置更新则 reload 即可:

    kill -HUP `cat /path/nginx/logs/nginx.pid`  
    /usr/local/nginx/sbin/nginx -s reload  


模块编译成功!


重启Nginx服务器!

在编译安装 Nginx 的第三方模块时,碰到一个错误:
    /usr/local/nginx/sbin/ngxin -s reload  
    /usr/local/nginx/sbin/nginx: error while loading shared libraries: libluajit-5.1.so.2: cannot open shared object file: No such file or directory  

百事不得其解,后来Google之,发现了解决办法。

在 Nginx 编译时,需要指定 RPATH,加入下面选项即可:
    ./configure --with-ld-opt="-Wl,-rpath,$LUAJIT_LIB"  
    或者  
    export LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH  
5、测试Lua
在Nginx.conf 配置文件中,加入以下代码:


    location /echo {  
        default_type 'text/plain';  
        echo 'hello echo';  
    }  
    location /lua {  
        default_type 'text/plain';  
        content_by_lua 'ngx.say("hello, lua")';  
    } 


重启Nginx服务器:
    /usr/local/nginx/sbin/nginx -s reload  
使用curl测试:
    [root@localhost] curl http://localhost/echo  
    hello echo  
    [root@localhost] curl http://localhost/lua  
    hello lua  

测试结果表明,两个模块都安装成功!

 

简洁版

 

Java代码 

 收藏代码

  1. wget http://nginx.org/download/nginx-1.2.7.tar.gz  
  2. wget http://luajit.org/download/LuaJIT-2.0.1.tar.gz  
  3. wget https://github.com/simpl/ngx_devel_kit/archive/v0.2.18.tar.gz  
  4. wget https://github.com/chaoslawful/lua-nginx-module/archive/v0.7.16.tar.gz  
  5.   
  6. tar xzf LuaJIT-2.0.1.tar.gz  
  7. cd LuaJIT-2.0.1  
  8. make  
  9. make install PREFIX=/usr/local/LuaJIT/  
  10.   
  11. cd ..  
  12. tar xzf nginx-1.2.7.tar.gz  
  13. tar xzf v0.2.18.tar.gz  
  14. tar xzf v0.7.16.tar.gz  
  15. cd nginx-1.2.7  
  16.   
  17. export LUAJIT_INC=/usr/local/LuaJIT/include/luajit-2.0  
  18. export LUAJIT_LIB=/usr/local/LuaJIT/lib  
  19. export LD_LIBRARY_PATH=/usr/local/lib/:$LD_LIBRARY_PATH  
  20.   
  21. ./configure –user=www –group=www –prefix=/usr/local/webserver/nginx –with-http_stub_status_module –with-http_ssl_module –add-module=/root/software/ngx_devel_kit-0.2.18 –add-module=/root/software/lua-nginx-module-0.7.16/  
  22. make  
  23. make insatll  
  24.   
  25.   
  26.   
  27.   
  28. ./configure --prefix=/usr/local/nginx/nginx-1.7.3 \  
  29. --sbin-path=/usr/local/nginx/nginx-1.7.3 \  
  30. --conf-path=/usr/local/nginx/nginx-1.7.3/conf/nginx.conf \  
  31. --with-http_ssl_module \  
  32. --with-openssl=/usr/local/nginx/openssl-1.0.1h \  
  33. --with-pcre=/usr/local/nginx/pcre-8.33 \  
  34. --with-zlib=/usr/local/nginx/zlib-1.2.8 \  
  35. --with-http_stub_status_module \  
  36. --add-module=/usr/local/nginx/ngx_devel_kit-0.2.18 \  
  37. --add-module=/usr/local/nginx/lua-nginx-module-0.7.16 \  
  38. --add-module=/usr/local/nginx/set-misc-nginx-module-0.27  

 

 

 

 

另一篇文章:http://sunjun041640.blog.163.com/blog/static/2562683220134931235857/

 

misc-nginx-module和lua-nginx-module插件具体文档可参考如下:

https://github.com/openresty/set-misc-nginx-module/tags

https://github.com/openresty/lua-nginx-module#installation

 

 

记录日志:

Java代码 

 收藏代码

  1. user  root;    
  2. worker_processes  1;    
  3.     
  4. #error_log  logs/error.log;    
  5. #error_log  logs/error.log  notice;    
  6. #error_log  logs/error.log  info;    
  7.     
  8. pid        logs/nginx.pid;    
  9.     
  10.     
  11. events {    
  12.     worker_connections  1024;    
  13. }    
  14.     
  15.     
  16. http {    
  17.     include       mime.types;    
  18.     default_type  application/octet-stream;    
  19.     log_format tick "$msec|||$u_t|||$remote_addr|||$u_domain|||$u_url|||$u_title|||$u_referrer|||$u_sh|||$u_sw|||$u_cd|||$u_lang|||$http_user_agent|||$u_utrace|||$u_account|||$u_time";    
  20.         
  21.     
  22.     #access_log  logs/access.log  main;    
  23.     sendfile        on;    
  24.     #tcp_nopush     on;    
  25.     
  26.     #keepalive_timeout  0;    
  27.     keepalive_timeout  65;    
  28.     
  29.     #gzip  on;    
  30.     
  31.     server {    
  32.         listen       80;    
  33.         server_name  localhost;    
  34.     
  35.         #charset koi8-r;    
  36.     
  37.     location /1.gif {    
  38.         #伪装成gif文件    
  39.         default_type image/gif;    
  40.         #本身关闭access_log,通过subrequest记录log    
  41.         access_log off;    
  42.         access_by_lua "    
  43.         -- 用户跟踪cookie名为__utrace    
  44.         local uid = ngx.var.cookie___utrace    
  45.         if not uid then    
  46.         -- 如果没有则生成一个跟踪cookie,算法为md5(时间戳+IP+客户端信息)    
  47.         uid = ngx.md5(ngx.now() .. ngx.var.remote_addr .. ngx.var.http_user_agent)    
  48.         end    
  49.         ngx.header['Set-Cookie'] = {'__utrace=' .. uid .. '; path=/'}    
  50.         if ngx.var.arg_domain then    
  51.         -- 通过subrequest到/i-log记录日志,将参数和用户跟踪cookie带过去    
  52.         ngx.location.capture('/i-log?' .. ngx.var.args .. '&utrace=' .. uid .. '&time=' .. ngx.localtime())    
  53.         end    
  54.         ";    
  55.         #此请求不缓存    
  56.         add_header Expires "Fri, 01 Jan 1980 00:00:00 GMT";    
  57.         add_header Pragma "no-cache";    
  58.         add_header Cache-Control "no-cache, max-age=0, must-revalidate";    
  59.         #返回一个1×1的空gif图片    
  60.         empty_gif;    
  61.         }    
  62.         location /i-log {    
  63.         #内部location,不允许外部直接访问    
  64.         internal;    
  65.      #设置变量,注意需要unescape    
  66.         set_unescape_uri $u_domain $arg_domain;    
  67.     set_unescape_uri $u_t $arg_t;    
  68.         set_unescape_uri $u_url $arg_url;    
  69.         set_unescape_uri $u_title $arg_title;    
  70.         set_unescape_uri $u_referrer $arg_referrer;    
  71.         set_unescape_uri $u_sh $arg_sh;    
  72.         set_unescape_uri $u_sw $arg_sw;    
  73.         set_unescape_uri $u_cd $arg_cd;    
  74.         set_unescape_uri $u_lang $arg_lang;    
  75.         set_unescape_uri $u_utrace $arg_utrace;    
  76.         set_unescape_uri $u_account $arg_account;    
  77.     set_unescape_uri $u_time $arg_time;    
  78.         #打开日志    
  79.         log_subrequest on;    
  80.         #记录日志到ma.log,实际应用中最好加buffer,格式为tick    
  81.         access_log /usr/local/nginx/nginxlog/access.log tick;    
  82.         #输出空字符串    
  83.         echo '';    
  84.         }    
  85.     
  86.         #error_page  404              /404.html;    
  87.     
  88.         # redirect server error pages to the static page /50x.html    
  89.         #    
  90.         error_page   500 502 503 504  /50x.html;    
  91.         location = /50x.html {    
  92.             root   html;    
  93.         }    
  94.         
  95.     # remove the robots line if you want to use wordpress' virtual robots.txt    
  96.         location = /robots.txt  { access_log off; log_not_found off; }    
  97.         location = /favicon.ico { access_log off; log_not_found off; }    
  98.         # this prevents hidden files (beginning with a period) from being served    
  99.         location ~ /\.          { access_log off; log_not_found off; deny all; }    
  100.     
  101.     }    
  102.     
  103.     
  104.     
  105. }   

 

本文转载自:http://liyonghui160com.iteye.com/blog/2164769

闪电
粉丝 75
博文 392
码字总数 6789
作品 0
海淀
技术主管
私信 提问
lua配合nginx进行代码(nginx配置文件)调试

nginx有echo模块可以实现输出字符串到web浏览器上,实现方式如下: 首先要nginx支持echo模块,然后在修改配置文件进行测试。 下载模块: 下载路径:https://github.com/openresty/echo-nginx...

xinsir999
2017/10/05
0
0
生产环境上nginx 不覆盖添加lua模块

需求如下: 需要在nginx配置文件中判断请求中是否带某参数变量,nginx配置本身没有此判断功能。 网上查找资料,可以在nginx中添加lua模块,使用lua的脚本去判断。比较靠谱的文章:CentOS系统...

-悟空-
2015/06/11
0
2
ubuntu安装nginx的lua模块

ubuntu安装nginx的lua模块 1.系统信息:cat /proc/version Linux version 3.5.0-25-generic (buildd@lamiak) (gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-2ubuntu1) ) #39-Ubuntu SMP Mon Feb......

seared2008
2013/12/19
0
0
nginx-openresty-windows 各个子模块更新V1.11.4.1001

最新版本 版本号:1.11.4.1001 32 位下载地址: http://pan.baidu.com/s/1o7ZBGz4 64 位下载地址: http://pan.baidu.com/s/1mig1zcs 发布时间: 2016-09-14 修改日志: Nginx: 更新 nginx core 到......

小东111
2016/09/18
1K
6
nginx-video-thumbextractor-module缩略图安装

部署环境centos7(其他安装参数根据需要选择) 1.nginx安装参数 ./configure --prefix=/usr/local/nginx --with-httpimagefiltermodule --with-httpstubstatusmodule --with-httpsslmodule --......

左客
2017/12/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

[转载]What Your Computer Does While You Wait

What Your Computer Does While You Wait https://manybutfinite.com/post/what-your-computer-does-while-you-wait/ Dec 1st, 2008 This post takes a look at the speed - latency and thr......

MtrS
26分钟前
0
0
springmvc的return “success”源码解读

qqqq

architect刘源源
今天
4
0
Java程序员五面阿里分享 逆袭成功 太不容易了!

前言 拿到阿里实习offer,经历了5次面试,其中4轮技术面,1轮HR面试。在这里分享一下自己的面试经验和学习心得。希望能够帮助更多的小伙伴。 我本科毕业于中南大学信管专业,真正开始学习Jav...

别打我会飞
昨天
4
0
Android Camera模块解析之视频录制

《Android Camera架构》 《Android Camera进程间通信类总结》 《Android Camera模块解析之拍照》 《Android Camera模块解析之视频录制》 《Android Camera原理之CameraDeviceCallbacks回调模...

天王盖地虎626
昨天
2
0
手把手教你使用issue作为博客评论系统

自从上周在阮一峰的 每周分享第 60 期 看到了可以将 GitHub 的 issue 当作评论系统,插入第三方网页的 JS 库——utterances。我就对此“魂牵梦绕”。个人博客使用的是VuePress。 TLDR (不多废...

jump--jump
昨天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部