4、Redis连接池的构建与测试

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 首先我们在我们的项目中新建一个 RedisPool类代码如下:package com.mmall.common;import com.mmall.

首先我们在我们的项目中新建一个 RedisPool
代码如下:

package com.mmall.common;

import com.mmall.util.PropertiesUtil;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * @author Chakid
 * @since 2018-10-30 20:15
 */
public class RedisPool {
    private static JedisPool pool; //jedis连接池

    //redis所在的IP
    private static String redisIp=PropertiesUtil.getProperty("redis.ip");

    //redis开放的端口
    private static Integer redisPort =Integer.parseInt(PropertiesUtil.getProperty("redis.port"));

    //jedis最大连接数
    private static Integer maxTotal= Integer.parseInt(PropertiesUtil.getProperty("redis.max.total","20"));

    //最大空闲连接数
    private static Integer maxIdle= Integer.parseInt(PropertiesUtil.getProperty("redis.max.idle","10"));

    //最小空闲连接数
    private static Integer minIdle= Integer.parseInt(PropertiesUtil.getProperty("redis.min.idle","2"));

    //从jedis连接池获取连接时,校验并返回可用的连接
    private static boolean testBorrow= Boolean.parseBoolean(PropertiesUtil.getProperty("redis.test.borrow","true"));

    //把连接放回jedis连接池时,校验并返回可用的连接
    private static boolean testReturn= Boolean.parseBoolean(PropertiesUtil.getProperty("redis.test.return","true"));


    //初始化连接池
    private static void initPool(){

        JedisPoolConfig config = new JedisPoolConfig();

        //给config set相关值
        config.setMaxTotal(maxTotal);
        config.setMaxIdle(maxIdle);
        config.setMinIdle(minIdle);
        config.setTestOnBorrow(testBorrow);
        config.setTestOnReturn(testReturn);

        //连接耗尽时,是否阻塞,false会抛出异常,true直到阻塞超时,默认为true
        config.setBlockWhenExhausted(true);

        pool = new JedisPool(config,redisIp,redisPort,1000*2);
    }


    //实例化连接池
    static {
        initPool();
    }

    //从连接池中获取一个连接对象
    public static Jedis getJedis(){
        return pool.getResource();
    }


    //如果是一个损坏连接就放在BrokenResource
    public static void returnBrokenResource(Jedis jedis){
        pool.returnBrokenResource(jedis);
    }

    //将jedis放回连接池
    public static void returnResource(Jedis jedis){
        pool.returnResource(jedis);
    }



    //用main测试我们的连接

    public static void main(String[] args) {
        Jedis jedis = pool.getResource();

        jedis.set("chakidkey","chakidvalue");

        returnResource(jedis);

        pool.destroy();

        System.out.println("program is end~");
    }

}

然后由于我是把配置信息单独配置多出来,如果只是单独测试 Jedis的连接的话,把我下面的对应参数填到上面即可~

#start redis config

#redis所在服务器IP
redis.ip=119.29.xx.xxx

#redis的端口
redis.port=6379

#最大连接数
redis.max.total=20

#最大空闲连接数
redis.max.idle=10

#最小空闲连接数
redis.min.idle=2

#从jedis连接池获取连接时,校验并返回可用的连接
redis.test.borrow=true

#把连接放回jedis连接池时,校验并返回可用的连接 return设置为false的时候,在并发量高的时候可以提高我们的并发效率
redis.test.return=false

#end redis config

相关代码的讲解都在注释中啦~
测试代码写好之后,接下来就是测试我们的连接了:
用Xshell连接我们的服务器,打开Redis服务


img_76439a0a12d034d6468ae56a1dcedc61.png
image.png

然后Xshell启动我们的连接客户端:

img_8ee5124ff21c82604527b050b68a3f73.png
image.png

发现原本存在一些,我先把里面的删掉,执行: flushall
img_c4bd9169f76aa60949c76b2700b72b12.png
image.png

好,发现所以key都被我们清空了,接下来就要运行我们上面编写的代码,直接运行 main函数即可~
OK,执行完毕,来看看我们的redis里面有没有我们刚才加的数据吧~
img_397d6900ea479115fc6547fbe5b9f115.png

咦,发现数据已经加进去了,那么测试也就成功啦~


img_ca2adbcc87e9cf187ecce086e7efc215.png
image.png
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
NoSQL Java 关系型数据库
mysql和redis连接池
mysql和redis连接池
23 0
|
3月前
|
关系型数据库 MySQL Java
mysql连接池和redis连接池的实现
mysql连接池和redis连接池的实现
41 0
|
4月前
|
测试技术 Docker 容器
使用Docker构建多环境应用:开发、测试、生产环境
Docker已经成为了现代应用程序开发和部署的核心工具之一。通过使用Docker,开发团队可以轻松地在不同的环境中构建、测试和部署应用程序,从而提高开发速度和应用程序的可移植性。本文将介绍如何使用Docker构建多环境应用,包括开发、测试和生产环境,并提供丰富的示例代码,以帮助大家轻松应对不同环境的挑战。
|
2月前
|
消息中间件 NoSQL Java
Redis Streams在Spring Boot中的应用:构建可靠的消息队列解决方案【redis实战 二】
Redis Streams在Spring Boot中的应用:构建可靠的消息队列解决方案【redis实战 二】
187 1
|
3月前
|
关系型数据库 MySQL Java
mysql连接池和redis连接池
mysql连接池和redis连接池
112 0
|
2月前
|
NoSQL Java 数据库连接
springboot整合Redis中连接池jedis与lettuce的对比和实现
springboot整合Redis中连接池jedis与lettuce的对比和实现
288 0
|
1月前
|
Java 测试技术 持续交付
【软件工程】单元测试:构建坚固软件基石的不可或缺一环
【软件工程】单元测试:构建坚固软件基石的不可或缺一环
21 0
|
2月前
|
存储 NoSQL 关系型数据库
轻松打卡:使用Spring Boot和Redis Bitmap构建高效签到系统【redis实战 四】
轻松打卡:使用Spring Boot和Redis Bitmap构建高效签到系统【redis实战 四】
61 0
|
2月前
|
NoSQL 关系型数据库 Java
【Redis刨析】知识图谱的构建与实现
【Redis刨析】知识图谱的构建与实现
|
3月前
|
测试技术 UED Python
使用Python构建自动化测试框架
本文介绍了如何使用Python语言构建一个强大的自动化测试框架,该框架可以帮助开发人员在软件开发过程中进行高效的测试工作。通过使用Python的强大功能和第三方库,我们可以轻松地编写、运行和管理各种测试用例,并生成详细的测试报告,提高软件质量和开发效率。

热门文章

最新文章