Redis连接池的配置与使用

Redis连接池

jedis连接资源的创建与销毁是很消耗程序性能,所以jedis为我们提供了jedis的池化技术,jedisPool在创建时初始化一些连接资源存储到连接池中,使用jedis连接资源时不需要创建,而是从连接池中获取一个资源进行redis的操作,使用完毕后,不需要销毁该jedis连接资源,而是将该资源归还给连接池,供其他请求使用。

下面给出 jedis详细配置的一些项

#最大总连接数     
redis.pool.maxTotal=1000 
   
#最大能够保持idel状态的对象数(最大活动树)   
redis.pool.maxIdle=100  
#最小能够保持idel状态的对象数(最小活动树)  
redis.pool.minIdle=50    

#当池内没有返回对象时,最大等待时间    
redis.pool.maxWaitMillis=10000    

#当调用borrow Object方法时,是否进行有效性检查    
redis.pool.testOnBorrow=true    
#当调用return Object方法时,是否进行有效性检查    
redis.pool.testOnReturn=true  

#“空闲链接”检测线程,检测的周期,毫秒数。如果为负值,表示不运行“检测线程”。默认为-1.  
redis.pool.timeBetweenEvictionRunsMillis=30000 
 
#向调用者输出“链接”对象时,是否检测它的空闲超时;  
redis.pool.testWhileIdle=true  

# 对于“空闲链接”检测线程而言,每次检测的链接资源的个数。默认为3.  
redis.pool.numTestsPerEvictionRun=50  

#redis服务器的IP    
redis.ip=xxxxxx  
#redis服务器的Port    
redis.port=6379 
下面就是JedisPool配置初始化过程
  1. jedis.propertis 这里就只配置了两个,就是最大连接数和最大活动数
host:127.0.0.1
port:6397
maxTotal=50
maxIdle=10
  1. JedisPoolUtil.java
package com.yjj.util;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * 加载配置文件,配置连接池参数
 * 提供链接的方法
 * @author Administrator
 *
 */
public class JedisPoolUtil {

	private static JedisPool jedisPool;
	
	//当类加载就读取配置文件
	static{
		//类加载加载配置文件
		InputStream is=JedisPoolUtil.class.getClassLoader().getResourceAsStream("jedis.properties");
		
		//创建Properties对象
		Properties pr=new Properties();
		try {
			//关联文件
			pr.load(is);
		} catch (IOException e) {
			e.printStackTrace();
		}
		
		//获取数据,设置数据
		JedisPoolConfig config=new JedisPoolConfig();
		//最大连接数
		config.setMaxTotal(Integer.parseInt(pr.getProperty("maxTotal")));
		//设置最大的空闲连接
		config.setMaxIdle(Integer.parseInt(pr.getProperty("maxIdle")));
		
		//初始化JedisPool
		jedisPool=new JedisPool(pr.getProperty("host"),Integer.parseInt(pr.getProperty("port")));
	}
	
	//获取Jedis
	public static Jedis getJedis(){
		return jedisPool.getResource();
	}
	
	//释放资源
	public static void closeJedis(Jedis jedis){
		if(jedis!=null){
			jedis.close();
		}
	}
}

  1. JedisPoolTest.java
package com.yjj.test;

import org.junit.Test;

import com.yjj.util.JedisPoolUtil;

import redis.clients.jedis.Jedis;

public class JedisPoolTest {

	@Test
	public void Test(){
		Jedis jedis=JedisPoolUtil.getJedis();
		jedis.set("hello", "hi");
		
		JedisPoolUtil.closeJedis(jedis);
	}
}

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
配置 Redis 连接池,你需要在 Redis配置文件中进行相应的设置。以下是一个示例配置: ``` # 最大连接数 maxclients 1000 # 连接池大小 # 如果设置为 0,则表示不使用连接池 # 如果设置为负数,则表示使用无限制的连接池 # 如果设置为正数,则表示连接池的大小 maxmemory 256mb # 设置连接池超时时间(单位:秒) timeout 30 # 开启 TCP KeepAlive 选项 tcp-keepalive 300 # 设置连接闲置超时时间(单位:秒) # 如果一个连接在指定的时间内没有进行任何操作,则会被关闭 tcp-keepalive-interval 60 # 开启 TCP NoDelay 选项 tcp-nodelay yes # 开启 TCP QuickAck 选项 tcp-quickack yes # 开启 SO_REUSEADDR 选项 tcp-reuseaddr yes # 开启 SO_KEEPALIVE 选项 tcp-keepalive yes # 开启 TCP_NODELAY 和 TCP_KEEPALIVE 选项 reliable yes # 设置连接池中连接的最大闲置时间(单位:秒) # 如果一个连接在指定的时间内没有被使用,则会被关闭 timeout 600 # 开启 TCP 连接复用(将多个请求复用到一个 TCP 连接)的选项 tcp-keepalive 300 # 设置连接复用的时间间隔(单位:毫秒) tcp-keepalive-interval 1000 # 开启单个连接的多个命令请求模式,以提高性能 # 该模式将多个命令一起发送到服务器,然后一起接收响应 # 但是需要注意的是,如果一个命令的执行时间过长,可能会导致后续命令的阻塞 # 默认情况下,该选项是关闭的 repl-disable-tcp-nodelay no ``` 你可以根据需要进行相应的调整和修改,然后将配置文件保存并重新启动 Redis 服务,新的配置将生效。记得备份原有的配置文件以防出现问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值