我打算使用编年史映射而不是redis,应用程序场景是memoryData模块每天从数据库启动以加载数亿条记录到编年史映射,并且数十个jvm继续读取编年史映射记录。每个jvm都有数百个线程。但可能是因为缺乏对历史记录映射的理解,代码性能不佳,运行速度较慢,直到内存溢出。我想知道上面的做法是否是对编年史地图的正确使用。
发布于 2017-03-30 14:50:42
由于编年史映射在堆外存储数据,它能够存储比您在主内存中可以容纳的数据更多的数据,但如果所有数据都可以放入内存中,性能会更好(因此,如果可能,请考虑增加机器内存,如果这不可能,请尝试使用SSD驱动器),性能低下的另一个原因可能是您在编年史映射构建器中调整映射的大小,例如,您如何设置最大条目的数量,如果太大,将影响性能。
https://stackoverflow.com/questions/42851160
复制相似问题