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 @ 2020-07-10 01:27  HumorChen99  阅读(3)  评论(0编辑  收藏  举报  来源