paulwong

          Spring Module---cache

          項目需要緩存,google了一下,發現spring module有現成的東西可用,隨即拿來看看。發現還是比較好用的。
          改cache采用了aop的方式進行cache的寫入和刷出。使用spring風格,上手容易。
          系統負載不高,因此對于該緩存方法的性能等等不做評價,目前滿足需要。
          使用方法:
          有這么幾個概念需要提前知道1.XXCacheFacade,比如如果是oscache,那么XX就是oscachefacade.該類負責緩存的寫入和刷出

          <bean id="oscacheFacade" class="org.springmodules.cache.provider.oscache.OsCacheFacade">  
              
          <property name="failQuietlyEnabled" value="true"/>  
              
          <property name="cacheManager">  
                  
          <bean id="oscacheManager" class="org.springmodules.cache.provider.oscache.OsCacheManagerFactoryBean"/>  
              
          </property>  
            
          </bean>  


          里面的cacheManager必須要有,改類負責提供底層具體的cache實現,比如oscache或者EHcache等。
          2.MethodMapCachingInterceptor這個攔截器是官方提供的同類型的攔截器之一,根據方法名,參數匹配攔截。

          <bean id="cachingInterceptor001" class="org.springmodules.cache.interceptor.caching.MethodMapCachingInterceptor">  
              
          <property name="cacheProviderFacade" ref="oscacheFacade"/>  
              
          <property name="cachingModels">  
                  
          <props>  
                      
          <prop key="com.company.jncz.TestItIF.get*">groups=aa;refreshPeriod=10</prop>  
                      
          <prop key="com.company.jncz.TestItIF.load*">groups=bb;refreshPeriod=10</prop>  
                  
          </props>  
              
          </property>  
            
          </bean>  


          注意cachingModels。有兩種方式寫法,一種是上面看到的使用props另一種是使用Map.在有些情況下只能使用Map方式,下面解釋

          <map>  
            
          <entry key="com.company.jncz.TestIt.get*">  
              
          <ref local="oscacheCachingModel"/>  
            
          </entry>  
          </map>  

           

           

          <bean id="oscacheCachingModel" class="org.springmodules.cache.provider.oscache.OsCacheCachingModel">  
              
          <property name="groups">  
                      
          <list>  
                         
          <value>aa</value>  
                         
          <value>bb</value>  
                      
          </list>  
                 
          </property>  
              
          <property name="refreshPeriod" value="10"/>  
           
          </bean>  


          尤其當groups(對于oscache來說是groups)的值不止一個的時候,就需要使用map的方式。
          否則不生效(也許還有什么我沒有注意到).另外需要注意的是對于model來說他的key很重要。有以下需要注意:如果AImpl是A接口的實現類,而且你在其他地方使用時都是用A接口來聲明的,那么key就必須寫成接口的全限定名比如:com.company.jncz.A.getXX,否則無法識別。

           

          對于與cachingModel相對應的flushingModel寫法是類似的,參考api很容易寫出來。

          最后

          <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">  
                  
          <property name="beanNames">  
                      
          <value>*Service</value>  
                  
          </property>  
                  
          <property name="interceptorNames">  
                      
          <list>  
                          
          <value>cachingInterceptor001</value>  
                          
          <value>flushingInterceptor001</value>  
                      
          </list>  
                  
          </property>  
            
          </bean>  
            
          <bean id="testService" class="com.company.jncz.TestItStub"/>  


          這些不做介紹。
          總之比較簡單。這兩天感冒,昏昏沉沉,不知道有沒有表達清楚。。。。

           

          自己看了一眼,的確沒說清楚,要清楚的幾個概念是cacheFacade.CachingModel.FlushingModel.CachingInterceptor.FlushingInterceptor.這些算是比較重要的。其他aop內容略。caching攔截器攔截某方法,根據cachingModel定義的規則由cacheFacade將之放入cache。flushing攔截器攔截到某方法,根據flushingModel定義的規則由cacheFacade將對應的cache清除。嗯,基本上流程就這樣子了。

          posted on 2007-07-16 17:01 paulwong 閱讀(1400) 評論(0)  編輯  收藏 所屬分類: J2EE

          主站蜘蛛池模板: 临安市| 玉田县| 扶风县| 康保县| 峨眉山市| 安龙县| 建昌县| 咸阳市| 连山| 驻马店市| 旅游| 昌图县| 呼和浩特市| 钦州市| 应城市| 东明县| 宜黄县| 慈利县| 茶陵县| 嘉祥县| 郎溪县| 威宁| 名山县| 嘉善县| 乌兰察布市| 山阴县| 台湾省| 阳东县| 本溪市| 沾益县| 福州市| 乐昌市| 彭阳县| 平乐县| 平乡县| 寿宁县| 梁山县| 东安县| 老河口市| 普宁市| 淳化县|