Fed*_*zza 7 java spring caching spring-boot spring-cache
我试图将缓存添加到CRUD应用程序,我开始执行以下操作:
@Cacheable("users")
List<User> list() {
return userRepository.findAll()
}
@CachePut(value = "users", key = "#user.id")
void create(User user) {
userRepository.create(user)
}
@CachePut(value = "users", key = "#user.id")
void update(User user) {
userRepository.update(user)
}
@CacheEvict(value = "users", key = "#user.id")
void delete(User user) {
userRepository.delete(user)
}
Run Code Online (Sandbox Code Playgroud)
我的问题是我希望create / update / delete操作可以为该操作更新已存储在缓存中的元素list()(请注意,list()不是从数据库中拉出而是从数据引擎中拉出),但是我无法做到这一点。
我想缓存list()单独返回的所有元素,以便所有其他操作可以使用来更新缓存#user.id。或者,可能需要执行所有操作来更新已存储在缓存中的列表。
我读到我可以在更新整个缓存时逐出整个缓存,但是我想避免这样的事情:
@CacheEvict(value = "users", allEntries=true)
void create(User user) {
userRepository.create(user)
}
Run Code Online (Sandbox Code Playgroud)
有什么方法可以在缓存的集合中创建/更新/删除值?还是将集合中的所有值作为单独的键缓存?
Fed*_*zza 11
我会自己回答我的问题,因为没有人给出任何并可以帮助他人。
我在处理这个问题时遇到的问题是对缓存使用的误解问题。我在这个问题上发布的需求与如何更新缓存列表的成员有关(方法响应)。这个问题不能用缓存解决,因为缓存的值是列表本身,我们不能部分更新缓存的值。
我想解决这个问题的方式与“地图”或分布式地图有关,但我想使用@Cacheable注释。通过使用分布式地图,无需使用@Cacheable. 因此,返回的列表可能已更新。
所以,我(想要)@Cacheable从其他角度解决这个问题。每当缓存需要更新时,我都会使用此代码对其进行刷新。
我使用下面的代码来解决我的问题:
@Cacheable("users")
List<User> list() {
return userRepository.findAll()
}
// Refresh cache any time the cache is modified
@CacheEvict(value = "users", allEntries = true")
void create(User user) {
userRepository.create(user)
}
@CacheEvict(value = "users", allEntries = true")
void update(User user) {
userRepository.update(user)
}
@CacheEvict(value = "users", allEntries = true")
void delete(User user) {
userRepository.delete(user)
}
Run Code Online (Sandbox Code Playgroud)
此外,我已启用 spring 缓存的日志输出以确保/了解缓存的工作方式:
# Log Spring Cache output
logging.level.org.springframework.cache=TRACE
Run Code Online (Sandbox Code Playgroud)
再一次,这不是第一次问这个问题。
再一次,答案是相同的。
我怀疑其中任何一个链接都会有所帮助,但也许从#3开始。
干杯,约翰
| 归档时间: |
|
| 查看次数: |
7615 次 |
| 最近记录: |