spring memcache 缓存

application-cache.xml的配置

在web.xml中引入了这个配置文件

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
                
                classpath*:application-cache.xml,
    </param-value>
  </context-param>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:context="http://www.springframework.org/schema/context" xmlns:cache="http://www.springframework.org/schema/cache"
        xsi:schemaLocation="
           http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/cache
           http://www.springframework.org/schema/cache/spring-cache.xsd">

    <!-- 引入properties配置文件 -->
    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="systemPropertiesModeName" value="SYSTEM_PROPERTIES_MODE_OVERRIDE" />
        <property name="ignoreResourceNotFound" value="true" />
        <property name="locations">
            <list>
                <value>classpath*:application.properties</value>
            </list>
        </property>
    </bean>
    <!-- 启用缓存注解功能,这个是必须的,否则注解不会生效,另外,该注解一定要声明在spring主配置文件中才会生效 -->  
    <cache:annotation-driven />
    
    <!-- 缓存管理 -->
    <bean name="cacheManager" class="com.google.code.ssm.spring.ExtendedSSMCacheManager">
        <property name="caches">
            <set>
                <bean class="com.google.code.ssm.spring.SSMCache">
                    <constructor-arg name="cache" index="0" ref="MyCache" />
                    <!-- 5 minutes -->
                    <constructor-arg name="expiration" index="1" value="${default.memcache.expiration}" />
                    <!-- @CacheEvict(..., "allEntries" = true) doesn't work -->
                    <constructor-arg name="allowClear" index="2" value="false" />
                </bean>
            </set>
        </property>
    </bean>
    
    <!-- 缓存配置 -->
    <bean name="MyCache" class="com.google.code.ssm.CacheFactory">
        <property name="cacheName" value="MyCache" />
        <property name="cacheClientFactory" ref="cacheClientFactory"/>
        <property name="addressProvider">
            <bean class="com.google.code.ssm.config.DefaultAddressProvider">
                <property name="address" value="${default.memcache.address}" />
            </bean>
        </property>
        <property name="configuration">
            <bean class="com.google.code.ssm.providers.CacheConfiguration">
                <!-- 是否使用哈希 --> 
                <property name="consistentHashing" value="true" />
            </bean>
        </property>
        <property name="defaultSerializationType"
            value="#{T(com.google.code.ssm.api.format.SerializationType).valueOf(@defaultSerializationTypeAsString)}" />
    </bean>
    
    <bean name="cacheClientFactory" class="com.google.code.ssm.providers.xmemcached.MemcacheClientFactoryImpl" />
    
    <bean name="defaultSerializationTypeAsString" class="java.lang.String">
        <constructor-arg value="#{systemProperties['ssm.defaultSerializationType']?:'JSON'}" />
    </bean>
</beans>

 

application.properties的配置 下面那个地址是我本机的地址

#memcached memcache server address
default.memcache.address=192.168.3.11:11211
#expire time unit:seconds
default.memcache.expiration=43200

 

    @Override
    @Cacheable(value = "MyCache",key="T(com.base.util.Constant).AREA_FULL_QUERYFORNAV")
    public List<Area> queryAllFirstArea(AreaPage page) {
        return dao.queryAllFirstArea(page);
    }

 

@Cacheaable的key是唯一的,当第一次访问的时候,会执行dao的方法,第二次访问的时候就不会访问数据库了,访问缓存去了。

 

    /**
     * 清空缓存
     */
    @Override
    @CacheEvict(value = "MyCache",key="T(com.base.util.Constant).AREA_FULL_QUERYFORNAV")
    public void clearCache() {
        System.out.println("清空缓存成功!!!");
        
    }

@CacheEvict 注解清空缓存,当下次要查询这个key的缓存时,会查询数据库,将查询的结果缓存起来,下次再查询就直接查缓存了。

要使用这个还得安装mecache。我安装的是window版的。mecache下载安装地址.

解压后把里面的所有文件放到一个地方。我放到地方是:E:\mecache

(1)在终端(也即 cmd 命令界面)下输入 E:\memcached\memcached.exe -d install 令名来执行安装!

(2) 再次在终端输入: E:\memcached\memcached.exe -d start 来启动 memcache 服务。(以后 memcached 将作为 windows 的一个服务每次开机时

自动启动。这样服务器端已经安装完毕了)

(3)检验是否安装成功,只需要在 CMD 下输入 telnet 127.0.0.1 11211 就可以知道(memcache 默认端口是 11211)。

现在已经是可以访问的了!!

posted @ 2015-01-21 20:05  Hong_Jerry  阅读(1231)  评论(0编辑  收藏  举报