缓存策略主要三方面:
缓存什么内容;
这是根据业务决定的,通常是把经常访问的,并且很少被改变的放入缓存。何时进行缓存;
一般有这么几种方式:①程序启动时就放入缓存,常见的代码表
②用户登陆进行缓存,一般是权限信息③第一次访问放入缓存,一般是写业务数据常被访问④新增的时候放入缓存。有时候防止表单重复提交,保证幂等性会往缓存中存token。提交操作之后就删除,再次提交就保证幂等性。或者扣款防止重复扣款,分布式的时候通常放在缓存中。当缓存空间已满时如何进行替换,即缓存替换算法
一般常见的缓存替换法有:FIFO:先进先出队列,根据缓存生成的顺序。
MySQL的 query cache,采用的就是这种简单的缓存更新策略LRU:最近最少使用,会把最近最少使用的淘汰掉。实际上是维护了一个队列存放,根据最近最少使用存放,每次被使用,把最近被使用的放到队列头部。
对于一些时效性的信息可以使用这种,比如当前热点信息。LFU:最近最常使用,根据使用的频率进行淘汰。
这种对于一些热点信息不友好,当前使用较多,过期之后虽然在缓存前面拍着但是并不被访问。LRFU:兼顾使用频率与使用的时间的策略。
可以自己调整。
memcached 的缓存更新策略是LRU算法,默认就是,无法选择。
ehcache 的缓存策略可以自己选择配置。
redis的缓存更新策略较为丰富,有三种,需要自己配置。