效率

變通實現(xiàn)微服務的per request以提高IO效率中提到的同一請求過程中對于同一個方法的多次讀取只實際調(diào)用一次,其余的讀取均從第一次讀取的結(jié)果緩存中獲取,以提高讀取的效率。實現(xiàn)方案是引入了Context對象,可以理解成上下文的一個環(huán)境變量,業(yè)務方法在獲取數(shù)據(jù)時先從Context中取,如果取不到從數(shù)據(jù)庫中加載并將結(jié)果寫入Context中,而Context是通過ThreadLocal來存儲。但實現(xiàn)有點復雜需要尋找優(yōu)化方案。

Context方案的缺點

  • 復雜度增強,因為需要引入Context的特殊概念

  • 復用性比較低。需要在Context中為每種數(shù)據(jù)維護一個屬性。比如存儲用戶,產(chǎn)品,價格等。當然也可以利用Map,這樣會導致復雜度會更加強,在緩存清除的時候也會隨著數(shù)據(jù)存儲結(jié)構的復雜度提升而提升:之前是為每種數(shù)據(jù)定義一個ThreadLocal。

private ThreadLocal<CiaUserInfo> ciaUserInfoThreadLocal=new ThreadLocal<>();
  • 需要在業(yè)務方法中嵌入操作Context的方法,具備比較強的代碼侵入性。下面代碼中的getCiauserInfoFromCache就嵌入在業(yè)務代碼中。

public CiaUserInfo getTokenInfo(String token) throws Exception {        CiaUserInfo result = this.productContext.getCiaUserInfoFromCache(token);        if(null!=result){            return result;
        }        else {
     &n
        
		

網(wǎng)友評論