鍍金池/ 教程/ Java/ Ubuntu 平臺安裝
定時任務
函數(shù)的參數(shù)
超時
一個 openresty 內(nèi)存“泄漏”問題
獲取 uri 參數(shù)
局部變量
sleep
灰度發(fā)布
TIME_WAIT
代碼覆蓋率
連接池
CentOS 平臺安裝
稀疏數(shù)組
如何只啟動一個 timer 工作?
變量的共享范圍
break,return 關鍵字
Nginx
SQL 注入
如何引用第三方 resty 庫
不同階段共享變量
獲取請求 body
動態(tài)生成的 lua-resty-redis 模塊方法
動態(tài)加載證書和 OCSP stapling
repeat 控制結構
編碼為 array 還是 object
Nginx 靜態(tài)文件服務
執(zhí)行階段概念
Lua 函數(shù)
日期時間函數(shù)
健康監(jiān)測
與其他 location 配合
for 控制結構
函數(shù)定義
HTTPS 時代
點號與冒號操作符的區(qū)別
String 庫
文件操作
OpenResty 最佳實踐
<code>ngx.shared.DICT</code> 非隊列性質(zhì)
使用動態(tài) DNS 來完成 HTTP 請求
代碼規(guī)范
什么是 JIT?
Windows 平臺安裝
正確的記錄日志
LuaNginxModule
不用標準庫
C10K 編程
控制結構
請求中斷后的處理
Lua 環(huán)境搭建
Test::Nginx 能指定現(xiàn)成的 nginx.conf,而不是自動生成一個嗎
Lua 基礎數(shù)據(jù)類型
動態(tài)限速
PostgresNginxModule
簡單API Server框架
API 測試
location 匹配規(guī)則
虛變量
單元測試
防止 SQL 注入
select + set_keepalive 組合操作引起的數(shù)據(jù)讀寫錯誤
阻塞操作
全動態(tài)函數(shù)調(diào)用
Web 服務
典型應用場景
Nginx 新手起步
TLS session resumption
輸出響應體
調(diào)用代碼前先定義函數(shù)
module 是邪惡的
怎樣理解 cosocket
模塊
Socket 編程發(fā)展
如何對 Nginx Lua module 添加新 api
如何在后臺開啟輕量級線程完成定時任務?
如何定位問題
table 庫
json 解析的異常捕獲
如何安裝火焰圖生成工具
lua 中如何 continue
if 是邪惡的
為什么我們的域名不能被解析
抵制使用 module() 定義模塊
測試
body 在 location 中的傳遞
Lua 入門
子查詢
pipeline 壓縮請求數(shù)量
如何發(fā)起新 HTTP 請求
Lua 簡介
緩存失效風暴
Ubuntu 平臺安裝
日志輸出
緩存
Lua 面向?qū)ο缶幊?/span>
Nginx 陷阱和常見錯誤
Redis 接口的二次封裝(發(fā)布訂閱)
日志
訪問有授權驗證的 Redis
正則表達式
lock
熱裝載代碼
調(diào)用 FFI 出現(xiàn) &quot;table overflow&quot;
數(shù)據(jù)合法性檢測
禁止某些終端訪問
控制結構 if-else
調(diào)試
與 Docker 使用的網(wǎng)絡瓶頸
PostgresNginxModule 模塊的調(diào)用方式
用 do-end 整理你的代碼
FFI
什么時候使用
簡介
環(huán)境搭建
Mac OS X 平臺安裝
火焰圖
負載均衡
while 型控制結構
如何定位 openresty 崩潰 bug
使用 Nginx 內(nèi)置綁定變量
判斷數(shù)組大小
請求返回后繼續(xù)執(zhí)行
Redis 接口的二次封裝
KeepAlive
反向代理
協(xié)議無痛升級
數(shù)學庫
元表
Vanilla 介紹
HelloWorld
LuaCjsonLibrary
持續(xù)集成
代碼靜態(tài)分析
網(wǎng)上有大量對 Lua 調(diào)優(yōu)的推薦,我們應該如何看待?
script 壓縮復雜請求
非空判斷
性能測試
函數(shù)返回值
API 的設計
kong 介紹
表達式
不支持事務
LuaRestyDNSLibrary 簡介

Ubuntu 平臺安裝

源碼包準備

我們首先要在官網(wǎng)下載 OpenResty 的源碼包。官網(wǎng)上會提供很多的版本,各個版本有什么不同也會有說明,我們可以按需選擇下載。 筆者選擇下載的源碼包為 ngx_openresty-1.9.7.1.tar.gz。

相關依賴包的安裝

首先你要安裝 OpenResty 需要的多個庫 請先配置好你的apt源,配置源的過程在這就不闡述了,然后執(zhí)行以下命令安裝OpenResty編譯或運行時所需要的軟件包。

# apt-get install libreadline-dev libncurses5-dev libpcre3-dev \
    libssl-dev perl make build-essential

如果你只是想測試一下OpenResty,并不想實際使用,那么你也可以不必去配置源和安裝這些依賴庫,請直接往下看。

OpenResty 安裝

  1. 在命令行中切換到源碼包所在目錄。
  2. 解壓源碼包,tar xzvf ngx_openresty-1.9.7.1.tar.gz。若你下載的源碼包版本不一樣,將相應的版本號改為你所下載的即可。
  3. 切換工作目錄到 cd ngx_openresty-1.9.7.1
  4. 了解默認激活的組件。OpenResty 官網(wǎng)有組件列表,我們可以參考,列表中大部分組件默認激活,也有部分默認不激活。 默認不激活的組件,我們可以在編譯的時激活,后面步驟詳說明。
  5. 配置安裝目錄及需要激活的組件。使用選項 --prefix=install_path,指定安裝目錄(默認為/usr/local/openresty)。

    使用選項 --with-Components 激活組件,--without 則是禁止組件。 你可以根據(jù)自己實際需要選擇 with 或 without。如下命令,OpenResty 將配置安裝在 /opt/openresty 目錄下(注意使用 root 用戶),并激活luajit、http_iconv_module 并禁止 http_redis2_module 組件。

      # ./configure --prefix=/opt/openresty\
                  --with-luajit\
                  --without-http_redis2_module \
                  --with-http_iconv_module
  6. 在上一步中,最后沒有什么 error 的提示就是最好的。若有錯誤,最后會顯示 具體原因可以看源碼包目錄下的 build/nginx-VERSION/objs/autoconf.err文件查看。若沒有錯誤,則會出現(xiàn)如下信息:

       Type the following commands to build and install:
           gmake
           gmake install
  7. 編譯:根據(jù)上一步命令提示,輸入gmake。
  8. 安裝:輸入gmake install。
  9. 上面的步驟順利完成之后,安裝已經(jīng)完成。可以在你指定的安裝目錄下看到一些相關目錄及文件。

設置環(huán)境變量

為了后面啟動 OpenResty 的命令簡單一些,不用在 OpenResty 的安裝目錄下進行啟動,我們設置環(huán)境變量來簡化操作。 將 nginx 目錄添加到 PATH 中。打開文件 /etc/profile, 在文件末尾加入export PATH=$PATH:/opt/openresty/nginx/sbin,若你的安裝目錄不一樣,則做相應修改。 注意:這一步操作需要重新加載環(huán)境變量才會生效,可通過命令source /etc/profile或者重啟服務器等方式實現(xiàn)。

接下來,我們就可以進入到后面的章節(jié) HelloWorld 學習。