由于需要在各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存储进去