Nginx Lua 之Shared Dict get()方法在存入字符串超长的情况下不支持高并发

由于需要在各worker之间共享一些关键数据,数据格式是表,选用了lua_shared_dict dict_name dict_size;这个共享内存功能

然而ngx.shared.dict只支持数字、字符串等基本数据类型,不支持表的存储,且需要通过get set方法保证并发时数据相对安全

由于不支持表的存储,随后我使用cjson将表转化为字符串进行存储,由于存储了十万条数据,造成这个字符串已经达到了10M之长,

经过测试ngx shared dict 的get set方法的性能并不差,再测试了cjson的转化效率,也不差,那么原因就在于这个十万条数据,得自己使用缓存等方案对性能进行优化

因此在这样的情况下,使得shared.dict:get()方法的性能下降到了100倍以上,因此对于这种存储的字符串内容超长的情况

建议降低数据维度,例如一个表拆分为每个key+value存储进去

posted @   HumorChen99  阅读(9)  评论(0编辑  收藏  举报  
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示