hystrix支持將一個請求結果緩存起來,下一個具有相同key的請求將直接從緩存中取出結果,減少請求開銷。要使用該功能必須管理HystrixRequestContext,如果請求B要用到請求A的結果緩存,A和B必須同處一個context。通過HystrixRequestContext.initializeContext()和context.shutdown()可以構建一個context,這兩條語句間的所有請求都處於同一個context,當然這個管理過程可以通過自定義的filter來實現。
Hystrix請求緩存註解
@CacheResult 加入該註解的方法將開啓請求緩存,默認情況下該方法的所有參數作爲緩存的key,也就是說只有該方法的所有參數都一致時纔會走緩存。
@Service
public class UserCacheService {
@Autowired
private UserFeignClient userFeignClient;
/**
* @HystrixCommand 的requestCache.enabled 可控制是否支持緩存
* 只有加了@CacheResult才能緩存,即使requestCache.enabled=true
* @param id 用戶id
* @return 指定的用戶
*/
@CacheResult
@HystrixCommand(commandProperties = {
@HystrixProperty(name="requestCache.enabled",value = "true")
})
public User findUserById(Integer id){
return userFeignClient.findUserById(id);
}
}
如果requestCache.enabled設置爲false,即使加了@CacheResult,緩存也不起作用。
@CacheKey 通過該註解可以指定緩存的key
@CacheResult
@HystrixCommand(commandProperties = {
@HystrixProperty(name="requestCache.enabled",value = "true")
})
public User findUserByIdAndName(@CacheKey Integer id,String name){
return userFeignClient.findUserById(id);
}
上面的代碼我們用@CacheKey修飾了id字段,說明只要id相同的請求默認都會走緩存,與name字段無關,如果我們指定了@CacheResult的cacheKeyMethod屬性,則@CacheKey註解無效
@CacheRemove 該註解的作用就是使緩存失效
/**
* 通過@CacheRemove 註解指定當調用findUserById時將此方法的緩存刪除
* @param id 用戶id
* @param name 用戶姓名
* @return 指定的用戶
*/
@CacheResult
@CacheRemove(commandKey = "findUserById")
@HystrixCommand(commandProperties = {
@HystrixProperty(name="requestCache.enabled",value = "true")
})
public User findUserByIdAndName2(@CacheKey Integer id,String name){
return userFeignClient.findUserById(id);
}
以上代碼指定了@CacheRemove的屬性commandKey的值爲findUserById,作用就是當調用findUserById時,此方法的緩存將刪除。