OpenResty之共享内存的使用

2 篇文章 0 订阅

1、定义共享内存100MB,nginx.conf配置文件http域增加如下指令代码:

 http {
     lua_shared_dict share_mem_cache 100m;
     ...
 }

2、使用共享内存:

    location /set {
        content_by_lua_block {
        local share_mem_cache  = ngx.shared.share_mem_cache
        share_mem_cache:set("name", "xiaoming") 
        ngx.say("STORED")
        }   
    }   

    location /get {
        content_by_lua_block {
        local share_mem_cache  = ngx.shared.share_mem_cache
        ngx.say(share_mem_cache:get("name"))
        }   
    } 

    location /capacity {
        content_by_lua_block {
            require "resty.core.shdict"
            local share_mem_cache  = ngx.shared.share_mem_cache
            ngx.say(share_mem_cache:capacity())
        }   
    }

3、另外,ngx_lua还提供很多相对安全的api接口操作共享内存。

  • get_stale()
  • safe_set()
  • safe_add()
OpenResty 是一个基于 Nginx 的全功能 Web 应用服务器,它通过在 Nginx 进程中嵌入 Lua 脚本解释器,使得开发者可以使用 Lua 脚本来扩展 Nginx 功能。 在 OpenResty 中,不同阶段的处理共享一个 Lua 虚拟机实例,这使得在不同的阶段可以共享变量和其他资源。具体而言,OpenResty 支持以下几个阶段的共享: 1. 预配置阶段:在这个阶段,可以使用 Lua 脚本动态地配置 Nginx 的一些基本参数,如 worker 数量、最大连接数等。这些配置可以在不重启服务的情况下实时生效。 2. 初始化阶段:通过在 init_worker_by_lua 阶段执行的 Lua 脚本,可以共享一些需要在所有工作进程内预先初始化的数据和资源。例如,可以在这个阶段初始化数据库连接池或加载一些共享代码库,以提高后续请求的处理效率。 3. 请求处理阶段:在 access_by_lua 阶段,可以共享在初始化阶段初始化的数据和资源。这些数据和资源可以用于处理用户请求,如访问一些共享的内存缓存、全局变量等。 4. 日志阶段:在 log_by_lua 阶段,可以将请求处理得到的信息记录到一个共享的日志文件中。这个共享的文件描述符可以在处理不同请求的不同阶段使用。 总之,OpenResty 的共享特性能够帮助开发者在不同阶段共享数据和资源,提高开发效率和性能。通过合理利用这些共享机制,可以实现更灵活、可扩展的 Web 应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值