Prefacio
Los dos primeros capítulos han descrito la instalación y el uso de openresty
Este capítulo describe principalmente la instalación y el uso de lua-protobuf en el entorno openresty.
1: Entorno
ubuntu18
lua-protobuf https://github.com/starwing/lua-protobuf
protobuf https://github.com/protocolbuffers/protobuf/releases/tag/v3.9.1 ##La mejor versión elige
openresty http: / /openresty.org/en/download.html
2: Instale openresty
1>
Las instrucciones oficiales de instalación de Openresty se pueden instalar en
http://openresty.org/cn/linux-packages.html
2> Instalación del código fuente
Dirección de descarga del código fuente: http://openresty.org/cn/download. html
Instrucciones de instalación: http://openresty.org/cn/installation.html
En Linux, generalmente necesita usar sudo para obtener privilegios de root para completar la instalación.
Instalar dependencias (primero sudo apt-get update para reemplazar la fuente doméstica más rápido)
sudo apt-get install libpq-dev
sudo apt-get install libpcre3-dev libssl-dev perl make build-essential curl
$HOME/software/openssl-OpenSSL_1_1_1u 源码解压缩文件夹 目录下包含 config文件 下面的是 OK 的
ubuntu@ubuntu:~/software/openresty-1.21.4.1$ ./configure --prefix=$HOME/openresty --with-luajit --without-http_redis2_module --with-http_iconv_module --with-http_postgres_module --with-openssl=$HOME/software/openssl-OpenSSL_1_1_1u
Agregue la variable de entorno
cd ~
vim .bashrc
PATH=/usr/local/openresty/nginx/sbin:$PATH
export PATH
start openresty
cd ~
mkdir work
cd work
mkdir src_lua ### Coloque todos los scripts lua en este directorio
mkdir conf El contenido de
vim nginx.conf es el siguiente
worker_processes 1;
error_log logs/error.log;
events {
worker_connections 1024;
}
http {
server {
listen 8080;
lua_code_cache off; ###lua_code_cache on;#调试模式(即关闭lua脚本缓存) //生产环境 on #修改lua文件不需要重新,立即生效
keepalive_timeout 60s; # 配置段: http, server, location 指定每个 TCP 连接最多可以保持多长时间。Nginx 的默认值是 75 秒,
#有些浏览器最多只保持 60 秒,所以可以设定为 60 秒。若将它设置为 0,就禁止了 keepalive 连接。
client_body_timeout 20s;# 配置段: http, server, location 指定客户端与服务端建立连接后发送 request body 的超时时间。
#如果客户端在指定时间内没有发送任何内容,Nginx 返回 HTTP 408(Request Timed Out)
client_header_timeout 10s;# 配置段: http, server, location 客户端向服务端发送一个完整的 request header 的超时时间。
#如果客户端在指定时间内没有发送一个完整的 request header,Nginx 返回 HTTP 408(Request Timed Out)
location /test {
default_type text/html;
content_by_lua_block {
ngx.say("<p>hello, world</p>");
ngx.say("nginx prefix ==> ",ngx.config.prefix());
}
}
location /testlua {
proxy_set_header X-real-ip $remote_addr; # 可直接获取客户端IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 通过代理服务器获取客户端IP
#lua_code_cache off; ###lua_code_cache on;#调试模式(即关闭lua脚本缓存) //生产环境 on
content_by_lua_file src_lua/http.lua;
}
location /testproto {
proxy_set_header X-real-ip $remote_addr; # 可直接获取客户端IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 通过代理服务器获取客户端IP
#lua_code_cache off; ###lua_code_cache on;#调试模式(即关闭lua脚本缓存) //生产环境 on
content_by_lua_file src_lua/testprotobuf.lua;
}
}
}
Hay comillas simples alrededor del comando de inicio pwd
cd ~/work
nginx -p pwd
/ -c conf/nginx.conf #Iniciar, especificar script de carga
nginx -p pwd
/ -c conf/nginx.conf -s detener #Detener
nginx -p pwd
/ -c conf/nginx_debug.conf -s recargar #recargar
o crear sh usted mismo
, como iniciar start.sh, el contenido es el siguiente
nginx -p pwd
/ -c conf/nginx.conf
Verificar configuración
nginx -t ##Verificar archivo de configuración predeterminado
nginx -t -c ~/work/conf/nginx.conf ###Verificar archivo de configuración personalizado
2: Instale lua-protobuf,
descargue y descomprima https://github.com/starwing/lua-protobuf
gcc -O2 -shared -fPIC pb.c -o pb.so -I /usr/local/openresty/luajit/include /luajit -2.1
/usr/local/openresty/luajit/include/luajit-2.1 Confirma si la ubicación es la misma o cambia la ubicación
Copie 4 archivos en el directorio lualib
sudo cp pb.so /usr/local/openresty/lualib
sudo cp protoc.lua /usr/local/openresty/lualib
sudo cp luaunit.lua /usr/local/openresty/lualib
sudo cp serpent .lua /usr/local/openresty/lualib
4: caso de uso de protobuf
referencia de codificación y decodificación de protobuf copiar el login.proto
de alguien en línea
syntax = "proto3";
package msg;
import "account.proto"; //proto full name
message Login_C {
Account account = 1;
}
message Login_S {
bool result = 1;
}
cuenta.proto
syntax = "proto3";
package msg;
message Account {
string username = 1;
string password = 2;
}
Comando de compilación
./protoc -I ./ -o proto.pb ./account.proto ./login.proto
Copie el proto.pb generado en el directorio src_lua/pb.
Los dos archivos .proto no son necesarios, por lo que se copian para facilitar su visualización.
5: Prueba
1> script de prueba
testprotobuf.lua
local lu = require "luaunit"
local pb = require "pb"
local pbio = require "pb.io"
local buffer = require "pb.buffer"
local slice = require "pb.slice"
local conv = require "pb.conv"
local protoc = require "protoc"
local serpent = require "serpent"
--ngx.say("123")
local path = ngx.config.prefix() .. "src_lua/pb/proto.pb"
--ngx.config.prefix()); --/home/ubuntu18/work/
--local P = protoc.new()
local file, msg = io.open(path, "rb")
if file ~= nil then
local buffer = file:read("*a")
pb.load(buffer)
file:close()
else
ngx.log(ngx.ERR, "读取文件失败: ", msg)
ngx.say("读取文件失败: ", msg)
return
end
ngx.say("124")
--ngx.say("pb.type",pb.type)
local data = {
account = {
username = "test",
password = "123456"
}
}
local data1 ={
result = 0
}
local bytes = pb.encode("msg.Login_S", data1) --08 01
local bytes1 = assert(pb.encode("msg.Login_C", data)) --0A 0E 0A 04 74 65 73 74 12 06 31 32 33 34 35 36
ngx.say(pb.tohex(bytes))
ngx.say(pb.tohex(bytes1))
local data2 = pb.decode("msg.Login_C", bytes1)
ngx.say(serpent.block(data2))
--[[
{
account = {
password = "123456",
username = "test"
} --table: 0x7fe5b6f2c808
} --table: 0x7fe5b6f2c788
--]]
El método de escritura de secuencias de comandos Lua puede hacer referencia a test.lua en lua-protobuf
2> Ejecutar
curl http://127.0.0.1:8080/testproto
6: Sube el proyecto DEMO si es necesario,
si lo encuentras útil, dale me gusta y agrega un favorito.