spring整合redis与接口封装

没整合前普通java程序:

导入jar包


无连接池创建链接

public class JedisDemo {

    public static void main(String[] args) {

        // 构造jedis对象

        Jedis jedis = new Jedis("127.0.0.1", 6380);

        // 向redis中添加数据

        jedis.set("mytest", "123");

        // 从redis中读取数据

        String value = jedis.get("mytest");

        System.out.println(value);

        // 关闭连接

        jedis.close();

   }

}

-----------------------------------------------------------------------

连接池中获取连接

public class JedisPoolDemo {

    public static void main(String[] args) {

        // 构建连接池配置信息

        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();

        // 设置最大连接数

        jedisPoolConfig.setMaxTotal(50);

        // 构建连接池

        JedisPool jedisPool = new JedisPool(jedisPoolConfig, "127.0.0.1", 6380);

        // 从连接池中获取连接

        Jedis jedis = jedisPool.getResource();

        // 读取数据

        System.out.println(jedis.get("mytest"));

        // 将连接还回到连接池中

        jedisPool.returnResource(jedis);

        // 释放连接池

        jedisPool.close();

    }

}

---------------------------------------------------------------

集群式的连接池

public class ShardedJedisPoolDemo {

    public static void main(String[] args) {

        // 构建连接池配置信息

        JedisPoolConfig poolConfig = new JedisPoolConfig();

        // 设置最大连接数

        poolConfig.setMaxTotal(50);

        // 定义集群信息

        List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();

        shards.add(new JedisShardInfo("127.0.0.1", 6379));

        shards.add(new JedisShardInfo("127.0.0.1", 6380));

        // 定义集群连接池

        ShardedJedisPool shardedJedisPool = new ShardedJedisPool(poolConfig, shards);

        ShardedJedis shardedJedis = null;

        try {

            // 从连接池中获取到jedis分片对象

            shardedJedis = shardedJedisPool.getResource();

            // 从redis中获取数据

            for(int i =0 ;i< 100 ;i++){

                shardedJedis.set("key"+i, "value"+i);

            }

            System.out.println("OK");

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            if (null != shardedJedis) {

                // 关闭,检测连接是否有效,有效则放回到连接池中,无效则重置状态

                shardedJedis.close();

            }

        }

        // 关闭连接池

        shardedJedisPool.close();

    }

}

--------------------------------------------------------------------------

spring整合redis

导入依赖

<!-- redis的java客户端 -->

<dependency>

        <groupId>redis.clients</groupId>

        <artifactId>jedis</artifactId>

</dependency>

②spring配置文件

<!-- 构建连接池配置信息 -->

<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">

        <!-- 设置最大连接数 -->

        <property name="maxTotal" value="${redis.maxTotal}"></property>

</bean>

<!-- 定义集群信息 -->

<bean id="shardedJedisPool" class="redis.clients.jedis.ShardedJedisPool">

       <constructor-arg index="0" ref="jedisPoolConfig"/>

            <constructor-arg index="1">

                <list>

                        <bean class="redis.clients.jedis.JedisShardInfo">

                                <constructor-arg index="0" value="${redis.host1}"/>

                                <constructor-arg index="1" value="${redis.port1}"/>

                           </bean>

                </list>

        </constructor-arg>

</bean>

接口封装

①封装回调接口

public interface Function<E,T> {

    public T callback(E e);

}

封装实现

@Service

public class RedisServiceImpl implements RedisService {

    //required=false在使用到才注入

    @Autowired(required=false)

    private ShardedJedisPool shardedJedisPool;       

    public <T> T excute(Function<ShardedJedis, T> fun){

        ShardedJedis shardedJedis = null;

        try {

            // 从连接池中获取到jedis分片对象

            shardedJedis = shardedJedisPool.getResource();

            // 从redis中设置key数据

           return fun.callback(shardedJedis);      

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            if (null != shardedJedis) {

                // 关闭,检测连接是否有效,有效则放回到连接池中,无效则重置状态

                shardedJedis.close();

            }

        }

        return null;

    } 

    @Override

    public String set(final String key,final String value) {

       return this.excute(new Function<ShardedJedis, String>() {

        @Override

        public String callback(ShardedJedis e) {

            return e.set(key, value);

        }

    });

    } 

    @Override

    public String get(final String key) {

        return this.excute(new Function<ShardedJedis, String>() {

 

            @Override

            public String callback(ShardedJedis e) {

                return e.get(key);

            }

        });

    } 

    @Override

    public Long del(final String key) {

        

        return this.excute(new Function<ShardedJedis, Long>() {

 

            @Override

            public Long callback(ShardedJedis e) {

                return e.del(key);

            }

        });

    }

    @Override

    public Long expire(final String key,final Integer seconds) {

        return this.excute(new Function<ShardedJedis, Long>() {

            @Override

            public Long callback(ShardedJedis e) {

                return e.expire(key, seconds);

            }

        });

    }

    @Override

    public Long expire(final String key, final String value, final Integer seconds) {

        return this.excute(new Function<ShardedJedis, Long>() {

            @Override

            public Long callback(ShardedJedis e) {

                e.set(key, value);

                return e.expire(key, seconds);

            }

        });

    }

}


------------------------------------------------------------


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
最近重构并优化了一套后端服务的代码: 1. 设计并开发高效的C++对象池算法,时间复杂度为 O(1) 在整个重构框架中,对象池是负责管理内存的底层基本模块 2. 利用命令模式的思想开发 Redis 子模块 抽象出方便高效的接口提供给上层程序员使用 3. 利用组合模式和装饰模式的思想开发 MongoDB 数据库查询条件装饰器 将查询条件和数据库 MongodbModule 数据模型进行解耦合 4. 抽象出一套 MongoDB Module 结果集接口 通过模板和特化技术实现 string/int 等不同索引类型的结果集 5. 开发 AbstractMongodbModule 类处理通用的 MongoDB 数据库表数据操作 数据库中不同的表都有自己的 AbstractMongodbModule 子类对应 6. 用 Perl 开发自动代码生成器,上层程序员对照数据库表结构写 .tmpl 配置文件, 自动生成该数据库表的 MongodbModule 子类,减轻程序员新增表时的工作量 7. 结合 Redis 模块和 MongoDB 模块,开发 HierarchicalModule 分层数据模型 构造一个 Redis 缓存层 + MongoDB 持久层的后台 Server 架构 并通过简单方便的接口供上层程序员使用,具体的数据分层处理对上层程序员是黑盒的 8. 设计并开发整套缓存层使用的 KEY 规则,方便缓存更新 结合公司的数据订阅系统进行 Redis缓存层 + MongoDB 持久层数据更新功能 9. 重构后的分层数据架构比原有接口效率提高 5 - 400 倍(返回数据记录条数从 150 - 5 条) 绝大部分时间后端接口需要获取记录个数在 50 以内,所以效率提升在 100 倍左右

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值