我有一个使用Spring构建的REST,为了提高我的一个端点的性能,我正在考虑使用内存中的数据库来进行更快的检索。
我要处理两个案子
对于第二个问题,我只想使用Spring的调度程序定期更新数据。
但是对于冷启动,我不知道什么是最好的解决方案,因为加载所有的初始数据可能是一个很长的过程。
发布于 2016-04-24 13:45:49
选择取决于你的SLA。如果您选择在API可用之前完成填充,则选择牺牲可用性以防止延迟响应。如果您选择在数据库异步填充时使API可用,则在填充数据库时,您将在前几个请求中牺牲响应时间。在你的SLA中哪一个是最重要的?正常运行时间还是响应时间?
如果您将拥有一组响应请求的服务器,优化正常运行时间没有好处,因为运行中的服务器将处理请求,而服务器需要花时间同步填充数据库;如果异步填充数据库,则如果刚启动的服务器开始接收请求,则客户端将遇到不必要的延迟。
还请考虑一下,如果一个数据库足够小,可以容纳到内存中(我知道,这只是一个讨论的假设),它可能不会花费足够长的时间来加载,从而产生很大的差异。
https://stackoverflow.com/questions/36819714
复制相似问题