jedis集成例子

作者官方网站: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);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值