jedispool 连接池_redis-cli连接redis数据库

jedispool 连接池_redis-cli连接redis数据库一、连接前的准备1.确保windows能够ping通linux,linux能够ping通windows。2.开放CentOS7的端口6379。firewall-cmd–add-port=6379/tcp–permanent3.注释掉redis.conf文件中的bind。#bind127.0.0.14….

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

目录

一、连接前的准备

二、使用JedisPool连接池创建连接

ThreadLocal为多线程保证一个线程始终同一个连接

多线程测试

三、配置多数据源 


一、连接前的准备

        1 . 确保windows能够ping通linux,linux能够ping通windows。

        2. 开放CentOS7的端口6379 。

      firewall-cmd –add-port=6379/tcp –permanent

        3. 将redis.conf文件中的bind 改为 0.0.0.0

      bind 0.0.0.0

        4. 需要给redis设置密码才能访问,要不然会提醒没有设置密码, 修改redis.conf配置文件,指定永久密码:  

     # requirepass foobared
       requirepass 123456   

        5. 将protecetd-mode 设置为no 

protected-mode no

        6. 启动服务器。

./redis-server ../redis.conf

        windows:

cd D:\Program Files\redis-server-5.0.9

d:

redis-server.exe redis.windows-service.conf

     jedispool 连接池_redis-cli连接redis数据库

二、使用JedisPool连接池创建连接

        添加pom依赖:

  <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.4.2</version>
</dependency>

        注:访问的地址为ping通linux的地址,可以先通过redis桌面程序RedisDesktopManager测试是否可以通,再进行如下的工作。

ThreadLocal为多线程保证一个线程始终同一个连接

定义RedisConstants常量

package com.bing.sh.redis;

public class RedisConstants {


    public static final String DEFAULT_REDIS_HOST = "localhost";
    //端口
    public static final int DEFAULT_REDIS_PORT = 6379;
    //密码
    public static final String DEFAULT_REDIS_PWD = "123456";

    public static final int DEFAULT_REDIS_MAX_ACTIVE = 1024;
    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
    public static final int DEFAULT_REDIS_MAX_IDLE = 200;
    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException
    public static final int DEFAULT_REDIS_MAX_WAIT = 10000;
    //连接超时的时间  
    public static final int DEFAULT_REDIS_TIMEOUT = 10000;
    // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
    public static final boolean DEFAULT_REDIS_TEST_ON_BORROW = true;
    // 默认数据库
    public static final int DEFAULT_REDIS_DATABASE = 0;


}

定义RedisProperty类:

package com.bing.sh.redis;


import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;


@Data
@AllArgsConstructor
@NoArgsConstructor
public class RedisProperty {

    //服务器IP地址
    private String host = RedisConstants.DEFAULT_REDIS_HOST;
    //端口
    private int port = RedisConstants.DEFAULT_REDIS_PORT;
    //密码
    private String pwd = RedisConstants.DEFAULT_REDIS_PWD;
    //连接实例的最大连接数
    private int maxActive = RedisConstants.DEFAULT_REDIS_MAX_ACTIVE;
    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
    private int maxIdle = RedisConstants.DEFAULT_REDIS_MAX_IDLE;
    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException
    private int maxWait = RedisConstants.DEFAULT_REDIS_MAX_WAIT;
    //连接超时的时间  
    private int timeout = RedisConstants.DEFAULT_REDIS_TIMEOUT;
    // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
    private boolean testOnBorrow = RedisConstants.DEFAULT_REDIS_TEST_ON_BORROW;
    //数据库模式是16个数据库 0~15
    public int defaultDatabase = RedisConstants.DEFAULT_REDIS_DATABASE;


}

         使用ThreadLocal存放Jedis实例,保证一个线程使用的连接始终是同一个, 获取连接的时候直接从ThreadLocal里拿

package com.bing.sh.redis;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.ObjectUtils;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class JedisTemplate {
    private static Logger logger = LoggerFactory.getLogger(JedisTemplate.class);


    private static ThreadLocal<Jedis> jedisThreadLocal = new ThreadLocal<>();


    private static JedisTemplate jedisTemplate = new JedisTemplate();

    private static JedisPoolConfig config;

    private static JedisPool jedisPool;


    public static JedisTemplate getJedisTemplate(RedisProperty prop) {
        if (jedisPool == null) {
            initJedisPool(prop.getHost(), prop.getPort(), prop.getPwd(), prop.getTimeout(), prop.getDefaultDatabase());
        }
        return jedisTemplate;
    }

    public static JedisTemplate getJedisTemplate() {
        RedisProperty prop = new RedisProperty();
        if (jedisPool == null) {
            initJedisPool(prop.getHost(), prop.getPort(), prop.getPwd(), prop.getTimeout(), prop.getDefaultDatabase());
        }
        return jedisTemplate;
    }


    static {
        config = new JedisPoolConfig();
        config.setMaxTotal(RedisConstants.DEFAULT_REDIS_MAX_ACTIVE);
        config.setMaxIdle(RedisConstants.DEFAULT_REDIS_MAX_IDLE);
        config.setMaxWaitMillis(RedisConstants.DEFAULT_REDIS_MAX_WAIT);
        config.setTestOnBorrow(RedisConstants.DEFAULT_REDIS_TEST_ON_BORROW);
    }


    public static JedisPool initJedisPool(String host, int port, String pwd, int timeout, int db) {
        jedisPool = new JedisPool(config, host, port, timeout, pwd, db);
        logger.info("init jedis pool success >>>" + jedisPool.hashCode());
        return jedisPool;
    }




    public Jedis getJedisConnection() {
        Jedis jedis = jedisThreadLocal.get();
        if (ObjectUtils.isEmpty(jedis)) {
            jedis = jedisPool.getResource();
            jedisThreadLocal.set(jedis);
        }
        return jedis;

    }

    public void releaseConnection() {
        Jedis jedis = jedisThreadLocal.get();
        if (!ObjectUtils.isEmpty(jedis)) {
            jedisPool.returnResource(jedis);
            System.out.println("线程 ID " + Thread.currentThread().getId() + " 释放连接, jedis code=" + jedis.hashCode() + " release success !");
        }
        jedisThreadLocal.remove();
    }


}

多线程测试

    public static void main(String[] args) {
        RedisProperty property = new RedisProperty();
        // 将自定义属性注入
        property.setPwd("mypassword");
        JedisTemplate jedisTemplate = JedisTemplate.getJedisTemplate(property);
        for (int i = 0; i < 10; i++) {
            new Thread(() -> {
                System.out.println("线程 ID " + Thread.currentThread().getId() + " 获取连接, jedis code=" + jedisTemplate.getJedisConnection().hashCode());
                jedisTemplate.releaseConnection();
            }).start();
        }
    }

jedispool 连接池_redis-cli连接redis数据库

三、配置多数据源 

       也可以采用如下的方式配置redis的多数据源,只要从jedisPoolsMap根据host取出连接池列表即可。

package com.bing.sh.redis;

import com.bing.sh.exception.custom.RedisInitException;
import com.bing.sh.utils.CollectionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

public class MultipleJedisTemplate extends RedisConn {
    private static Logger logger = LoggerFactory.getLogger(MultipleJedisTemplate.class);

    private static MultipleJedisTemplate multipleJedisTemplate = new MultipleJedisTemplate();


    private static Map<String/**host**/, List<JedisPool>> jedisPoolsMap = new ConcurrentHashMap<>();


    public static Map<String, List<JedisPool>> getJedisPoolsMap() {
        return jedisPoolsMap;
    }


    public List<JedisPool> getJedisPoolsByHost(String host) {
        List<JedisPool> jedisPools = jedisPoolsMap.get(host);
        logger.info(host + " get jedis pool " + jedisPools);
        if (CollectionUtils.isNotEmpty(jedisPools)) return jedisPools;
        throw new RedisInitException(host + "has no JedisPoll found ! please init first");
    }


    private static void initMultipleJedisPool(List<RedisProperty> props) {
        props.forEach((prop) -> {
            String host = prop.getHost();
            List<JedisPool> jedisPools = jedisPoolsMap.get(host);
            if (CollectionUtils.isEmpty(jedisPools)) {
                jedisPools = new ArrayList<>();
            }
            jedisPools.add(new JedisPool(poolConfig, prop.getHost(), prop.getPort(), prop.getTimeout(), prop.getPwd(), prop.getDefaultDatabase()));
            jedisPoolsMap.put(host, jedisPools);
        });
    }


    public static MultipleJedisTemplate getMultipleJedisTemplate(List<RedisProperty> props) {
        if (CollectionUtils.isEmpty(props)) {
            throw new RedisInitException("init jedis fail >>> no properties input !");
        }
        initMultipleJedisPool(props);
        return multipleJedisTemplate;
    }


    @Override
    void setConfig(JedisPoolConfig config) {
        poolConfig = config;
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197166.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Django设置超时时间_东1时区

    Django设置超时时间_东1时区前言我们都知道时区,标准时区是UTC时区,django默认使用的就是UTC时区,所以我们存储在数据库中的时间是UTC的时间,但是当我们做的网站只面向国内用户,或者只是提供内部平台使用,我们希望存储在

    2022年8月7日
    9
  • C#Random()函数详解「建议收藏」

    C#Random()函数详解「建议收藏」随机数的使用很普遍,可用它随机显示图片,用它防止无聊的人在论坛灌水还可以用来加密信息等等。本文讨论如何在一段数字区间内随机生成若干个互不相同的随机数,比如在从1到20间随机生成6个互不相同的整数,并通过此文介绍Visualc#中随机数的用法。.net.Frameword中提供了一个专门产生随机数的类System.Random,此类默认情况下已被导入,编程过程中可以直接使用。我们知道,计算机并不…

    2022年5月18日
    40
  • 中文按字母排序_怎么按首字母顺序排

    中文按字母排序_怎么按首字母顺序排        项目中用到前端排序,自己写了一个实现,给大家分享一下。      存在的问题:很多时候是用汉字的首拼来比较,但汉字转拼音在前端实现是个问题,主要表现在两个地方1、字符库里的数据量没有覆盖所有汉字,2、多音字问题(注:这里都是说简体汉字)。      实现思路:1、从网上找了一个汉字转拼音的库,能转大部分汉字(多音字也没处理);2、写一个字符比较的函数;3、调用Array里的…

    2022年10月12日
    5
  • ERP和MES、QAS以及APS在制造企业信息化的了解

    ERP和MES、QAS以及APS在制造企业信息化的了解ERP系统企业ERP系统标准的定义来自其英文原意,即企业资源规划(EnterpiseResourcePlanning)。企业ERP系统是一个对企业资源进行有效共享与利用的系统,通过信息系统对信息进行充分整理、有效传递、使企业的资源在购、存、产、销、人、财、物等各个方面能够得到合理地配置与利用,从而实现企业经营效率地提高。从本质上讲,企业ERP系统时一套信息系统,是一种工具。系统设计中可集成某些管理思想与内容,可帮助企业提升管理水平。另外一种说法认为企业ERP系统是将企业所有资源进行整合集成管理,简单

    2022年6月28日
    33
  • Ubuntu安装配置MySQL_nginx upstream

    Ubuntu安装配置MySQL_nginx upstream系Ubuntu安装配置nginx提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加例如:第一章Python机器学习入门之pandas的使用提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录系Ubuntu安装配置nginx前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。

    2026年1月20日
    3
  • Java NIO详解[通俗易懂]

    Java NIO详解[通俗易懂]JAVANIO简介NIO与IO的对比

    2022年7月8日
    19

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号