日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

安装OpenResty,实现分发层、应用层nginx+lua开发(附加问题:bad argument #2 to ‘set_keepalive‘ (number expected, got nil)

發布時間:2025/3/19 编程问答 72 豆豆
生活随笔 收集整理的這篇文章主要介紹了 安装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)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。