OpenResty入门与实践:下载安装、环境变量、常用命令及案例解析

文章目录

  • 一、Openresty下载安装
  • 二、设置环境变量
  • 三、常用命令
  • 四、入门案例
  • 五、实践案例
    • 1、lua-nginx-module
      • 1)入门案例
      • 2)获取Nginx uri中的单一变量
      • 3)获取Nginx uri中的所有变量
    • 2、Nginx缓存
      • 1)Nginx全局共享内存缓存
      • 2)lua-resty-lrucache
      • 3)http_proxy 本地磁盘缓存
    • 4、lua-resty-redis
    • 5、redis2-nginx-module
  • 总结
    • 1、安装过程中,出现http://vault.centos.org/centos/7/extras/x86_64/repodata/repomd.xml: [Errno 14] HTTPS Error 404 - Not Found
    • 2、使用redis2-nginx-module的时候,写了set方法,url传了key和val的值,但val为空

一、Openresty下载安装

官方地址:http://openresty.org/cn/linux-packages.html
安装过程,参考官方,按照下面步骤执行即可,如下:

CentOS 8 或者更老版本
# add the yum repo:
wget https://openresty.org/package/centos/openresty.repo
sudo mv openresty.repo /etc/yum.repos.d/openresty.repo

# update the yum index:
sudo yum check-update

然后就可以像下面这样安装软件包,比如 openresty:
sudo yum install -y openresty

如果你想安装命令行工具 resty,那么可以像下面这样安装 openresty-resty 包:
sudo yum install -y openresty-resty
命令行工具 opm 在 openresty-opm 包里,而 restydoc 工具在 openresty-doc 包里头。

默认安装目录:/usr/local/openresty

二、设置环境变量

  • 打开 ~/.bashrc 文件
    vi ~/.bashrc
  • 在文件末尾添加以下内容,保存并退出文件
    export PATH=/usr/local/openresty/nginx/sbin:$PATH
  • 使配置生效
    source ~/.bashrc

三、常用命令

  • 启动OpenResty:nginx 或 systemctl start openresty
  • 停止OpenResty:nginx -s stop 或 systemctl stop openresty
  • 重启OpenResty:systemctl restart openresty
  • 检查OpenResty配置文件语法:nginx -t
  • 查看OpenResty进程:ps -ef | grep nginx
  • 查看OpenResty版本:nginx -v
  • 查看OpenResty服务日志:sudo journalctl -u openresty
  • 设置开机启动:systemctl enable openresty
  • 重新加载配置文件:nginx -s reload 或 systemctl reload openresty 或 service openresty reload

四、入门案例

启动:systemctl start openresty
检查OpenResty的启动状态:systemctl status openresty
OpenResty入门与实践:下载安装、环境变量、常用命令及案例解析_第1张图片

编辑配置文件vi /usr/local/openresty/nginx/conf/nginx.conf,清空其它内容,设置为下面内容,方便测试

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {
    server {
        listen 8080;
        location / {
            default_type text/html;
            content_by_lua_block {
                ngx.say("

hello, world

"
) } } } }

重新加载配置:systemctl reload openresty
测试:curl http://localhost:8080/

[root@localhost ~]# curl http://localhost:8080/

hello, world</p>

浏览器访问ip验证:http://yourIp:8080/
在这里插入图片描述

五、实践案例

接下来通过多个实践案例,来了解下可以实现啥功能

1、lua-nginx-module

1)入门案例

在/usr/local/openresty/nginx/conf/lua目录下,创建外部lua脚本hello.lua

ngx.say("

Hello, World!

"
)

在/usr/local/openresty/nginx/conf目录下,创建lua.conf

server {
	listen       80;
	server_name  localhost;
	location /lua {
		default_type text/html;
		content_by_lua_file /usr/local/openresty/nginx/conf/lua/hello.lua;
	}
}

在nginx.conf下引入lua配置,写在http模块中
OpenResty入门与实践:下载安装、环境变量、常用命令及案例解析_第2张图片

重新加载配置,测试效果如下:

nginx -s reload
[root@localhost test]# curl http://localhost:80/lua

Hello, World!</p>

2)获取Nginx uri中的单一变量

写在我们前面定义的server中即可,端口还是80

location /nginx_var {
	default_type text/html;
	content_by_lua_block {
		ngx.say(ngx.var.arg_name)
	}
}

测试效果如下,只能获取一个变量

[root@localhost test]# curl http://localhost:80/nginx_var?name=forlan
forlan
[root@localhost test]# curl http://localhost:80/nginx_var?name=forlan&id=1
[1] 15536

3)获取Nginx uri中的所有变量

写在我们前面定义的server中即可,端口还是80

location /nginx_var {
	default_type text/html;
	content_by_lua_block {
		local uri_args = ngx.req.get_uri_args()  
			for k, v in pairs(uri_args) do  
			    if type(v) == "table" then  
			        ngx.say(k, " : ", table.concat(v, ", "), "
"
) else ngx.say(k, ": ", v, "
"
) end end } }

测试效果如下,可以正常获取多个变量
在这里插入图片描述

2、Nginx缓存

1)Nginx全局共享内存缓存

在Nginx配置中定义了一个共享字典,名为shared_data,大小为1MB,检查在共享字典中的变量i是否存在,如果不存在,就将其初始化为1,并存储到共享字典中。然后,将变量i的值增加1,并输出变量i的新值。这个过程是线程安全的,因为共享字典确保了在多进程环境中的数据一致性。

http {
	lua_shared_dict shared_data 1m;
	server {
		listen 8081;
		location /forlan {
			default_type text/html;
			content_by_lua_block {
				local shared_data = ngx.shared.shared_data
                local i = shared_data:get("i")
                if not i then
                    i = 1
                    shared_data:set("i", i)
                    ngx.say("lazy set i ", i, "
"
) end i = shared_data:incr("i", 1) ngx.say("i=", i, "
"
) } } } }

测试效果如下:
OpenResty入门与实践:下载安装、环境变量、常用命令及案例解析_第3张图片

2)lua-resty-lrucache

Lua 实现的一个简单的 LRU 缓存,适合直接缓存较为复杂的 Lua 数据
相比 ngx_lua 共享内存字典可以省去较昂贵的序列化操作
相比 memcached 这样的外部服务又能省去较昂贵的 socket 操作

lrucache 有两种实现:

  • resty.lrucache:适合用来缓存命中率高或读远远大于写操作的缓存业务
  • resty.lrucache.pureffi:适合用来缓存命中率低或需要对key进行频繁增、删操作的缓存业务

下面我们以resty.lrucache来演示下:
  在/usr/local/openresty/nginx/conf/lua目录下,创建外部lua脚本mycache.lua

local lrucache = require("resty.lrucache")  
--创建一个新的LRU缓存实例,大小为200
local cache, err = lrucache.new(200)  
if not cache then  
   ngx.log(ngx.ERR, "create cache error : ", err)  
end  
  
local function set(key, value, ttlInSeconds)  
    cache:set(key, value, ttlInSeconds)  
end  
  
local function get(key)  
    return cache:get(key)  
end  
  
local _M = {  
  set = set,  
  get = get  
}  
return _M

配置nginx.conf

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {
    lua_package_path "/usr/local/openresty/nginx/conf/lua/?.lua;;";
    server {
        listen 8081;
        location /forlan {
            default_type text/html;
            content_by_lua_block {
                local mycache = require("mycache")
                local count = mycache.get("count") or 0
                count = count + 1
                mycache.set("count", count, 10)
                ngx.say(mycache.get("count"))
            }
        }
    }
}

测试效果如下:不断累加,过了10s,缓存失效,从0开始
OpenResty入门与实践:下载安装、环境变量、常用命令及案例解析_第4张图片

3)http_proxy 本地磁盘缓存

http {  
    # 启用代理缓存  
    proxy_cache on;  
  
    # 指定代理缓存目录  
    proxy_cache_path /path/to/your/cache/directory levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m use_temp_path=off;  
  
    # 定义代理缓存区域  
    proxy_cache_key $scheme$proxy_host$request_uri;  
  
    # 配置哪些请求不参与代理缓存  
    proxy_no_cache $request_uri;  
  
    # 其他Nginx配置项...  
}

请确保将/path/to/your/cache/directory替换为你自己的实际磁盘缓存目录路径,并根据你的需求调整其他参数

4、lua-resty-redis

配置nginx.conf

server {
	listen 8082;
	location /forlan {
        default_type text/html;
        content_by_lua_block {
			local redis = require "resty.redis"  
			local red = redis:new()  
			
			local ok, err = red:connect("127.0.0.1", 6379) 
			if not ok then  
				ngx.log(ngx.ERR, "failed to connect to Redis: ", err)  
				return ngx.exit(500)  
			end 

			local ok, err = red:auth("root")  
			if not ok then  
				ngx.log(ngx.ERR, "failed to authenticate with Redis: ", err)  
				return ngx.exit(500)  
			end
			
			local res, err = red:get("forlan")
            ngx.say("res:",res)
        }
    }
}

重新加载配置,访问即可,如下,取到了Redis缓存的值

[root@localhost conf]# nginx -s reload
[root@localhost conf]# curl http://192.168.56.100:8082/forlan
res:xx

5、redis2-nginx-module

redis2-nginx-module是一个支持 Redis 2.0 协议的 Nginx upstream 模块,它可以让 Nginx 以非阻塞方式直接防问远方的 Redis 服务,同时支持 TCP 协议和 Unix Domain Socket 模式,并且可以启用强大的 Redis 连接池功能

提供一个set方法,通过url访问指定key和value,如:curl ”http://192.168.56.100:8082/set?key=forlan&val=2”

location = /set {
default_type text/html;
	redis2_pass 127.0.0.1:6379;
	redis2_query auth root;
     set_unescape_uri $key $arg_key;
     set_unescape_uri $val $arg_val;
     redis2_query set $key $val;
}

通过一个get方法,通过url访问获取key的值,如:curl “http://192.168.56.100:8082/get?key=forlan”

location = /get {
default_type text/html;
     redis2_pass 127.0.0.1:6379;
     redis2_query auth root;
     set_unescape_uri $key $arg_key;
     redis2_query get $key;
}

测试如下,试验成功

[root@localhost ~]# curl "http://192.168.56.100:8082/set?key=forlan&val=2"
+OK
+OK
[root@localhost ~]# curl "http://192.168.56.100:8082/get?key=forlan"
+OK
$1
2

很少使用这种的,因为复杂业务写起来很痛苦

总结

1、安装过程中,出现http://vault.centos.org/centos/7/extras/x86_64/repodata/repomd.xml: [Errno 14] HTTPS Error 404 - Not Found

进入目录:cd /etc/yum.repos.d
查看yum源:ll
重置:rm -f ${文件名}.repo

2、使用redis2-nginx-module的时候,写了set方法,url传了key和val的值,但val为空

location = /set {
default_type text/html;
	redis2_pass 127.0.0.1:6379;
	redis2_query auth root;
     set_unescape_uri $key $arg_key;
     set_unescape_uri $val $arg_val;
     redis2_query set $key $val;
}

上面这个配置这样写是没错的,错就错在访问的时候,我们使用了下面这种,忘记加了双引号,会导致val的值拿不到

curl http://192.168.56.100:8082/set?key=forlan&val=2

正确的访问方式应该是下面这种:

curl "http://192.168.56.100:8082/set?key=forlan&val=2"

你可能感兴趣的:(运维,openresty)