安装OpenResty,实现分发层、应用层nginx+lua开发(附加问题:bad argument #2 to ‘set_keepalive‘ (number expected, got nil)
1. 安裝OpenResty
1.1 在 /usr 目錄下創建servers目錄,并進入該目錄執行 yum install -y readline-devel pcre-devel openssl-devel gcc 指令安裝第三方庫。
1.2 使用 wget http://openresty.org/download/ngx_openresty-1.7.7.2.tar.gz 指令下載Nginx并解壓
1.3 進入?ngx_openresty-1.7.7.2/bundle/LuaJIT-2.1-20150120/ 目錄使用 make clean && make && make install 安裝lua,安裝后使用 ln -sf luajit-2.1.0-alpha /usr/local/bin/luajit 指令將luajit指令進行軟鏈接。
1.4 返回bundle目錄,下載其它兩個依賴并解壓,指令如下。
cd /usr/servers/ngx_openresty-1.7.7.2/bundle wget http://github.com/FRICKLE/ngx_cache_purge/archive/2.3.tar.gz tar -zxvf 2.3.tar.gzwget https://github.com/yaoweibin/nginx_upstream_check_module/archive/v0.3.0.tar.gz tar -zxvf v0.3.0.tar.gz注:當解壓v0.3.0.tar.gz壓縮包時,最后解壓到test目錄時會報錯,這個錯誤可不用管,如下圖。
1.5 返回nginx主目錄 /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
1.6 然后執行 make && make install 指令進行安裝
1.7 最后返回到 /usr/servers 目錄執行 nginx/sbin/nginx -V 查看版本,結果如下。
1.8 在 /usr/servers 目錄執行 nginx/sbin/nginx 指令就啟動了nginx
2. nginx配置
2.1?使用 vi /usr/servers/nginx/conf/lua.conf 指令編輯lua.conf文件,添加如下內容。
server {listen 80;server_name _;location /lua {default_type 'text/html';content_by_lua 'ngx.say("hello lhj")';} }2.2?使用 vi /usr/servers/nginx/conf/nginx.conf 指令編輯nginx.conf文件,在http部分添加如下三行內容。
lua_package_path "/usr/servers/lualib/?.lua;;"; lua_package_cpath "/usr/servers/lualib/?.so;;"; include lua.conf;2.3 可使用 nginx/sbin/nginx -t 指令驗證是否配置正確,正確結果如下。
2.4 重新啟動nginx指令是 /usr/servers/nginx/sbin/nginx -s reload ,啟動后瀏覽器輸入IP/lua即可得到輸出內容,如下圖。
2.5 lua腳本支持內嵌,我們可以在lua.conf中的localtion /lua{}代碼塊中,使用content_by_lua_file 指令指向某個lua文件,然后相關內容寫在那個lua文件即可,如下圖。
2.6 查看異常日志指令
tail -f /usr/servers/nginx/logs/error.log
3 分發層nginx的配置
3.1 分發層nginx需要發送http請求給應用層nginx,所以需要安裝http相關的依賴,去GitHub這個頁面下載依賴,如下圖所示。
下載后,把依賴放在 /usr/servers/lualib/resty 目錄下,如下所示。
3.2 在分發層nginx中的lua腳本存放目錄 /usr/servers/nginx/conf/lua/ 新建一個lua腳本,命名為dis.lua,添加以下代碼,實現簡單的分發邏輯。
local uri_args = ngx.req.get_uri_args(); local productId = uri_args["productId"];local hosts = {"192.168.56.101", "192.168.56.102"}; local hash = ngx.crc32_long(productId); local index = (hash % 2) + 1; backend = "http://"..hosts[index];local requestPath = uri_args["requestPath"]; requestPath = "/"..requestPath.."?productId="..productIdlocal http = require("resty.http"); local httpc = http.new();local resp, err = httpc:request_uri(backend,{method = "GET",path = requestPath,keepalive = false # 不加這一個參數,會報錯bad argument #2 to # 'set_keepalive' (number expected, got nil) })if not resp thenngx.say("request err: ", err);return; endngx.say(resp.body) httpc:close();并在 /usr/servers/nginx/conf/lua.conf 引入該dis.lua文件。
3.3 效果驗證,我們在應用層nginx1和nginx2分別寫上不同的輸出語句,然后通過nginx分發層傳入不同的productId哈希后進行分發,效果如下。
4. Nginx的介紹及優點
4.1 Nginx:一款輕量級的Web服務器;①在高并發響應中性能較好,因為是epoll模型,而Apache采用select模型;②反向代理性能強,可實現負載均衡;③內存和CPU占用率。
4.2 負載均衡:在lua.conf中配置upstream代碼段,目前upstream支持的分配算法:①輪詢(默認方式):每個請求按時間順序逐一分配到應用服務器;②權重:通過權重,使輪詢幾率和訪問比率成正比;③ip_哈希算法:對每個請求按照訪問ip進行hash,可解決session問題(其它解決session方案:a. 在多臺服務器上復制;b. 第三方緩存;c. cookie記錄session)。
?4.3 內存和CPU占用率低:采取分階段資源分配技術,處理靜態文件和無緩存的反向代理加速。
?
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的安装OpenResty,实现分发层、应用层nginx+lua开发(附加问题:bad argument #2 to ‘set_keepalive‘ (number expected, got nil)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 搭建第一个SpringBoot工程;Sp
- 下一篇: lua脚本简单编辑及常用指令