企業級java springcloud b2bc商城系統開源源碼二次開發-hystrix 請求緩存

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時,此方法的緩存將刪除。

java springboot b2b2c shop 多用戶商城系統來源

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章