效率

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

Context方案的缺點(diǎn)

  • 復(fù)雜度增強(qiáng),因?yàn)樾枰隒ontext的特殊概念

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

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

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