作者官方网站:http://www.wxl568.cn
包引用
<!-- 项目依赖spring -->
<dependencies>
<!-- spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>1.8.3.RELEASE</version>
</dependency>
<?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:task="http://www.springframework.org/schema/task"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
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/task
http://www.springframework.org/schema/task/spring-task-3.2.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
<bean class="com.sf.hrss.clock.util.SpringContextUtils"/>
<!-- 扫描service-->
<context:component-scan base-package="com.sf.hrss.clock.service.impl" >
<context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
<!-- 排除 -->
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Repository"/>
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!-- 事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="multiDataSource"></property>
</bean>
<!-- 事务策略 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<!-- 定义方法的过滤规则 -->
<tx:attributes>
<!-- 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。 -->
<tx:method name="add*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="insert*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="save*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="delete*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="edit*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<tx:method name="update*" propagation="REQUIRED" rollback-for="java.lang.Exception" />
<!-- 支持当前事务,如果当前没有事务,就以非事务方式执行。 -->
<tx:method name="list*" propagation="SUPPORTS" rollback-for="java.lang.Exception" />
<tx:method name="get*" propagation="SUPPORTS" rollback-for="java.lang.Exception" />
</tx:attributes>
</tx:advice>
<!-- AOP策略 -->
<aop:config>
<!-- 定义一个切入点 -->
<aop:pointcut id="transaction" expression="execution (* com.sf.hrss.*.service.impl.*.*(..))"/>
<!-- 对切入点和事务的通知,进行适配 -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="transaction"/>
</aop:config>
<!-- 缓存 -->
<bean id="clockCache" class="com.sf.hrss.clock.cache.handler.ClockDataCacheHandler"/>
<!-- 操作日志 -->
<bean class="com.sf.hrss.clock.util.OperationLogUtil">
<property name="opLogServiceImpl" ref="opLogServiceImpl"></property>
</bean>
edisj《《开始
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="2048" />
<property name="maxIdle" value="200" />
<property name="numTestsPerEvictionRun" value="1024" />
<property name="timeBetweenEvictionRunsMillis" value="30000" />
<property name="minEvictableIdleTimeMillis" value="-1" />
<property name="softMinEvictableIdleTimeMillis" value="10000" />
<property name="maxWaitMillis" value="1500" />
<property name="testOnBorrow" value="true" />
<property name="testWhileIdle" value="true" />
<property name="testOnReturn" value="false" />
<property name="jmxEnabled" value="true" />
<property name="blockWhenExhausted" value="false" />
</bean>
<bean id="redisSentinelConfiguration"
class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
<property name="master">
<bean class="org.springframework.data.redis.connection.RedisNode">
<property name="name" value="HRSS_REDIS_GPS_C01">
</property>
</bean>
</property>
<property name="sentinels">
<set>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="hrss-gps1.cachesit.sfdc.com.cn" />
<constructor-arg name="port" value="8001" />
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="hrss-gps2.cachesit.sfdc.com.cn" />
<constructor-arg name="port" value="8001" />
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode ">
<constructor-arg name="host" value="hrss-gps3.cachesit.sfdc.com.cn" />
<constructor-arg name="port" value="8001" />
</bean>
<!-- <bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="10.202.114.65" />
<constructor-arg name="port" value="8001" />
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="10.202.114.66" />
<constructor-arg name="port" value="8001" />
</bean>
<bean class="org.springframework.data.redis.connection.RedisNode ">
<constructor-arg name="host" value="10.202.114.67" />
<constructor-arg name="port" value="8001" />
</bean> -->
</set>
</property>
</bean>
<bean id="redisConnectionFactory"
class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:password="hac8rgltmoj5d8p0">
<constructor-arg name="sentinelConfig" ref="redisSentinelConfiguration"></constructor-arg>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
</bean>
<!--对key的默认序列化器。默认值是StringSerializer-->
<bean id="keyStringRedisSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer" />
<!--是对value的默认序列化器,默认值是取自DefaultSerializer的JdkSerializationRedisSerializer。-->
<bean id="valueJacksonSerializer" class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer" />
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="redisConnectionFactory" />
<!-- 对key和value进行序列化 -->
<property name="keySerializer" ref="keyStringRedisSerializer" />
<!--是对value的默认序列化器,默认值是取自DefaultSerializer的JdkSerializationRedisSerializer。-->
<property name="valueSerializer" ref="valueJacksonSerializer" />
</bean>
</beans>
后端代码使用
@Service
public class ClusterRedisServiceImpl implements ClusterRedisService{
private static final Logger logger = Logger.getLogger(ClusterRedisServiceImpl.class);
@Autowired
private RedisTemplate jedisCluster;
@Autowired
private EmployeeService employeeServiceImpl;
@Override
public void getClusterRedis() {
RedisTemplate<String, Object> template = (RedisTemplate<String, Object>)jedisCluster;
List<Employee> employeeInfo = this.employeeServiceImpl.listEmpInfoAll();//推广人员封装
for (Employee employee : employeeInfo) {
template.opsForValue().set(employee.getEmpCode(), employee);
}
}
@Override
public Employee getEmpInfoClusterRedis(String keyEmpCode) {
logger.info("RediskeyEmpCode:"+keyEmpCode);
RedisTemplate<String, Object> template = (RedisTemplate<String, Object>)jedisCluster;
return (Employee)template.opsForValue().get(keyEmpCode);
}