Ngx+Lua+Redis 快速存储POST数据

系统几万台设备有windows有安卓还有linux系统,每个设备三分钟就会向服务器post设备的硬件信息,数据格式json,后台管理界面只需要最新的数据,不需要历史数据,业务逻辑非常简单,PHP代码就几行,已经优化到极致了,但是架不住频率太高了。服务器负载就被这个的简单逻辑给耗尽。历史原因客户端已经不可能修改,只能在服务端进行优化了。

做法也很简单就是不用php-fpm,nginx接收到数据,直接把post数据存储到redis里面,供管理后台直接使用。

ngx如何连接redis请参考我的另一篇文件
Ngx+Lua+Redis 实时IP黑名单系统https://blog.csdn.net/hangbobo/article/details/142763400在这里我只接上代码

复制代码
local my_cache = ngx.shared.my_cache
local redis_connect=loadstring(my_cache:get("redis_connect"))
local red=redis_connect()
red:hincrby('store_ip:02','hardware',1)

local auth_header = ngx.req.get_headers()["Authorization"]
if string.len(auth_header) > 8 then
    local token = string.sub(auth_header,8)
    if string.len(token) > 0 then
        ngx.req.read_body() 
        
        local data = ngx.req.get_body_data()
        local cjson = require "cjson.safe"
        local obj = cjson.decode(data)
        obj.time=os.date("%Y-%m-%d %H:%M:%S", ngx.time())
        data=cjson.encode(obj)
        red:hset('hardware',token,data)
        ngx.say('{"msg":"succeed","status_code":200,"data":['..data..']}')
        ngx.exit(200)
    end
end
ngx.exit(404)

解析json代码并增加当前时间这个是非必须的,只是为了验证数据是不是最新提交的。

我的设备唯id是,通过header头的"Authorization" 传递的,你需要结合你你的实际代码。

代码存储为 /www/server/nginx/conf/hardware.lua

nginx配置

复制代码
lua_shared_dict my_cache 10m;
server
{
    listen 80;
    listen 443 ssl;
    http2 on;
    ...........
    
    default_type 'application/json';    
    access_by_lua_file /www/server/nginx/conf/access.lua; 

    location /boxs/hardware {
        access_by_lua_file /www/server/nginx/conf/hardware.lua;
    }

    ...........
}
相关推荐
十五年专注C++开发26 分钟前
Oat++: 一个轻量级、高性能、零依赖的 C++ Web 框架
开发语言·c++·web服务·oatpp
陈天伟教授27 分钟前
心电心音同步分析-案例:原型设计一
开发语言·人工智能·python·语言模型·架构
Allen_LVyingbo30 分钟前
量子计算Dirac Notation基本教学—从零基础到读懂量子信息论文(下)
开发语言·人工智能·python·数学建模·量子计算
上海合宙LuatOS36 分钟前
LuatOS扩展库API——【exmodbus】MODBUS协议
物联网·lua·luatos
wjs202438 分钟前
Ruby File 类和方法
开发语言
xyq202441 分钟前
API 类别 - UI 核心
开发语言
Dxy12393102161 小时前
Python路径算法简介
开发语言·python·算法
文慧的科技江湖1 小时前
光储充协同的终极闭环:用SpringCloud微服务打造“发-储-充-用“智能能源网络 - 慧知开源充电桩管理平台
java·开发语言·spring cloud·微服务·能源·充电桩开源平台·慧知重卡开源充电桩平台
東雪木1 小时前
Java学习——内部类(成员内部类、静态内部类、局部内部类、匿名内部类)的用法与底层实现
java·开发语言·学习·java面试
昵称暂无11 小时前
通过 C# 复制 Word 文档、指定段落、指定节
开发语言·c#·word