用jedis获取redis连接(集群和非集群状态下)
2016-03-22 17:40
555 查看
第一:非集群状态下
非集群状态下用Jedis获取redis连接,得到Jedis对象即可,一共有两种:
1.利用Jedis构造器,仅限用于测试,在实际项目中肯定是用JedisPool。
Jedis(String host);
Jedis(String host , int port);
2.利用JedisPool
主要是利用Jedis jedis=jedisPool.getResource();
JedisPool有N多个构造器,常用的构造器参数有GenericObjectPoolConfig poolConfig,String host,int port,int timeout,String password,创建GenericObjectPoolConfig对象时我们一般用其子类JedisPoolConfig (redis.clients.jedis.JedisPoolConfig),timeout是连接redis服务器的超时时间,以毫秒为单位,一般设置为0,如果不设为0,则不可设置太小,如果设成1、2,那么可能因为网络原因在1毫秒、2毫秒之内没有连上服务器而报错。见下例:
如上,创建出一个JedisPool对象,然后调用其getResource()方法获取redis连接即可,之后就可以调用Jedis API操作redis了。jedis连接用完要释放即close,如果不close,则产生的连接会越来越多,当达到了最大连接数,再想获得连接,就会等待,当超过了最大等待时间后就会报异常。
如果用了spring框架,则可以用spring管理redis连接池,在spring配置文件中配置如下:
这样就可以在要用到jedis连接的类中注入jedisPool对象,从而通过jedisPool.getResource()得到一个redis连接。
第二:集群状态下
集群状态下用Jedis获取redis连接,是得到JedisCluster对象,之后对redis进行操作都是用此对象的方法进行的:
如果用了spring框架的话,则非常简单
非集群状态下用Jedis获取redis连接,得到Jedis对象即可,一共有两种:
1.利用Jedis构造器,仅限用于测试,在实际项目中肯定是用JedisPool。
Jedis(String host);
Jedis(String host , int port);
2.利用JedisPool
主要是利用Jedis jedis=jedisPool.getResource();
JedisPool有N多个构造器,常用的构造器参数有GenericObjectPoolConfig poolConfig,String host,int port,int timeout,String password,创建GenericObjectPoolConfig对象时我们一般用其子类JedisPoolConfig (redis.clients.jedis.JedisPoolConfig),timeout是连接redis服务器的超时时间,以毫秒为单位,一般设置为0,如果不设为0,则不可设置太小,如果设成1、2,那么可能因为网络原因在1毫秒、2毫秒之内没有连上服务器而报错。见下例:
public static void main(String[] args) { JedisPoolConfig poolConfig = new JedisPoolConfig(); // 最大连接数 poolConfig.setMaxTotal(2); // 最大空闲数 poolConfig.setMaxIdle(2); // 最大允许等待时间,如果超过这个时间还未获取到连接,则会报JedisException异常: // Could not get a resource from the pool poolConfig.setMaxWaitMillis(1000); JedisPool pool = new JedisPool(poolConfig, "192.168.83.128", 6379, 0, "123"); Jedis jedis = null; try { for (int i = 0; i < 5; i++) { jedis = pool.getResource(); jedis.set("foo" + i, "bar" + i); System.out.println("第" + (i + 1) + "个连接, 得到的值为" + jedis.get("foo" + i)); // 用完一定要释放连接 jedis.close(); } } finally { pool.close(); } }
如上,创建出一个JedisPool对象,然后调用其getResource()方法获取redis连接即可,之后就可以调用Jedis API操作redis了。jedis连接用完要释放即close,如果不close,则产生的连接会越来越多,当达到了最大连接数,再想获得连接,就会等待,当超过了最大等待时间后就会报异常。
如果用了spring框架,则可以用spring管理redis连接池,在spring配置文件中配置如下:
<!-- 属性注入 --> <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxIdle" value="300" /> <!--最大能够保持idel状态的对象数 --> <property name="maxTotal" value="60000" /><!--最大分配的对象数 --> <property name="testOnBorrow" value="true" /><!--当调用borrow Oject方法时,是否进行有效性检查 --> </bean> <!-- 构造注入 --> <bean id="jedisPool" class="redis.clients.jedis.JedisPool"> <constructor-arg name="poolConfig" ref="jedisPoolConfig" /> <constructor-arg name="host" value="192.168.220.128" /> <constructor-arg name="port" value="6379" type="int" /> <constructor-arg name="timeout" value="10000" type="int" /> <constructor-arg name="password" value="123" /> </bean>
这样就可以在要用到jedis连接的类中注入jedisPool对象,从而通过jedisPool.getResource()得到一个redis连接。
第二:集群状态下
集群状态下用Jedis获取redis连接,是得到JedisCluster对象,之后对redis进行操作都是用此对象的方法进行的:
如果用了spring框架的话,则非常简单
相关文章推荐
- Linux下php安装Redis扩展
- Redis 学习 ---- 8.对象
- Redis 数据持久化(一)
- redis 的基本语法
- Linux下redis的安装
- day10-redis操作
- Redis 协议为例谈简单的协议分析
- Redis 协议为例谈简单的协议分析
- Redis 与 数据库处理数据的两种模式(转)
- php5.5.12+redis2.6 Windwos安装下安装
- redis安装及数据类型简介(string、list、set、sorted_set、hash)
- 【redis】跟着redis tutorial的基本学习
- 互联网架构设计之Redis篇-【Redis Windows版本安装过程】
- 互联网架构设计之Redis篇-【Redis的概述】
- service redis does not support chkconfig的解决办法
- redisTemplate keys方法 为空
- redis 学习笔记(7)-cluster 客户端(jedis)代码示例
- Redis的11种Web应用场景
- redis spring 集成
- Python使用Redis实现作业调度系统(超简单)