3

バックエンドが Spring と Hibernate で作成されたアプリケーションがあります。

アプリケーションをよりスケーラブルにするために memcaching を適用したいと考えています。最初は、hibernate の 2 番目のレベルのキャッシュを memcache と統合できると考えていましたが、問題は、アプリケーションで記述されたすべての HQL が book.grade.id のようで、Book と Grade が 2 つの別個のエンティティであるため、2 番目のレベルキャッシュ メカニズムが失敗しました。

キャッシングを実装する方法を誰かに勧めてもらえますか? 私は EHCache を見てきましたが、今のところ Memcache の実装が必要です。私のアプリケーションは複数のサーバーにヒットしますが、存在するデータベース サーバーは 1 つだけです。必要な条件を考えると、何か推奨事項はありますか?

4

1 に答える 1

0

以下に、従うことができる手順を示します。

  1. pom.xml が変更され、memcache の抽象キャッシュ メカニズムと、xmemcache を使用したクライアント実装が含まれるようになりました。

    com.google.code.simple-spring-memcached スプリング キャッシュ 3.1.0

    <dependency>
        <groupId>com.google.code.simple-spring-memcached</groupId>
        <artifactId>xmemcached-provider</artifactId>
        <version>3.1.0</version>
    </dependency>
    

注 : これは aop ベースであるため、cglib も含める必要があります。

  1. configuration.xml ファイルの変更

   **defining beans**

    <bean name="cacheManager" class="com.google.code.ssm.spring.SSMCacheManager">
 <property name="caches">
     <set>
         <bean class="com.google.code.ssm.spring.SSMCache">
             <constructor-arg name="cache" index="0" ref="defaultCache"/>
             <!-- 5 minutes -->
             <constructor-arg name="expiration" index="1" value="300"/>
             <!-- @CacheEvict(..., "allEntries" = true) doesn't work -->
             <constructor-arg name="allowClear" index="2" value="false"/>
         </bean>
     </set>
 </property>

</bean>


<bean name="defaultCache" class="com.google.code.ssm.CacheFactory">
    <property name="cacheName" value="defaultCache" />
    <property name="cacheClientFactory">
        <bean name="cacheClientFactory"
            class="com.google.code.ssm.providers.xmemcached.MemcacheClientFactoryImpl" />
    </property>
    <property name="addressProvider">
        <bean class="com.google.code.ssm.config.DefaultAddressProvider">
            <property name="address" value="x.x.x.x:11211" />
        </bean>
    </property>
    <property name="configuration">
        <bean class="com.google.code.ssm.providers.CacheConfiguration">
            <property name="consistentHashing" value="true" />
        </bean>
    </property>

</bean>
  1. サンプルメソッド...

    @Cacheable(value="defaultCache", key="new Integer(#id).toString().concat('.BOOKVO')") public BookVO getBookById(Integer id){

    ... }

この変更により、memcache サーバーでキーが見つからない場合にのみ、メソッドがデータベースにヒットします。

于 2014-07-28T08:08:58.360 に答える