redis Java客户jedis的使用。


Redis 简介:

redis是用C语言开发的一个开源的高性能键值对(key-value)数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:字符串类型、散列类型、列表类型、集合类型、有序集合类型。

Redis主要应用场景如下:

1、缓存(数据查询、短连接、新闻内容、商品内容等等)(最多使用)

2、分布式集群架构中的session分离。

3、任务队列。(秒杀、抢购、12306等等)

4、应用排行榜。

5、网站访问统计。

6、数据过期处理(可以精确到毫秒)

-------由于本文重点介绍jedis的使用,redis安装不再介绍。---------

jedis的使用:

JAR包


1、jedis链接单机版。

    // 单实例连接redis
    @Test
    public void testJedisSingle() {
       Jedisjedis = new Jedis("192.168.101.3", 6379);
       jedis.set("name", "bar");
       Stringname = jedis.get("name");
       System.out.println(name);
       jedis.close();
    }

2、使用连接池链接。

@Test
public void pool() {
	JedisPoolConfig config = new JedisPoolConfig();
	//最大连接数
	config.setMaxTotal(30);
	//最大连接空闲数
	config.setMaxIdle(2);

	JedisPool pool = new JedisPool(config, "192.168.101.3", 6379);
	Jedis jedis = null;
	try  {
		jedis = pool.getResource();
		jedis.set("name", "lisi");
		String name = jedis.get("name");
		System.out.println(name);
	}catch(Exception ex){
		ex.printStackTrace();
	}finally{
		if(jedis != null){
			//关闭连接
			jedis.close();
		}
	}
}


3、集群连接。

// 连接redis集群
@Test
public void testJedisCluster() {

	JedisPoolConfig config = new JedisPoolConfig();
	// 最大连接数
	config.setMaxTotal(30);
	// 最大连接空闲数
	config.setMaxIdle(2);

	//集群结点
	Set<HostAndPort> jedisClusterNode = new HashSet<HostAndPort>();
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7001));
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7002));
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7003));
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7004));
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7005));
	jedisClusterNode.add(new HostAndPort("192.168.101.3", 7006));
	JedisCluster jc = new JedisCluster(jedisClusterNode, config);
		
	JedisCluster jcd = new JedisCluster(jedisClusterNode);
	jcd.set("name", "zhangsan");
	String value = jcd.get("name");
	System.out.println(value);
}

4、spring整合。

<!-- 连接池配置 -->
	<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
		<!-- 最大连接数 -->
		<property name="maxTotal" value="30" />
		<!-- 最大空闲连接数 -->
		<property name="maxIdle" value="10" />
		<!-- 每次释放连接的最大数目 -->
		<property name="numTestsPerEvictionRun" value="1024" />
		<!-- 释放连接的扫描间隔(毫秒) -->
		<property name="timeBetweenEvictionRunsMillis" value="30000" />
		<!-- 连接最小空闲时间 -->
		<property name="minEvictableIdleTimeMillis" value="1800000" />
		<!-- 连接空闲多久后释放, 当空闲时间>该值 且 空闲连接>最大空闲连接数 时直接释放 -->
		<property name="softMinEvictableIdleTimeMillis" value="10000" />
		<!-- 获取连接时的最大等待毫秒数,小于零:阻塞不确定的时间,默认-1 -->
		<property name="maxWaitMillis" value="1500" />
		<!-- 在获取连接的时候检查有效性, 默认false -->
		<property name="testOnBorrow" value="true" />
		<!-- 在空闲时检查有效性, 默认false -->
		<property name="testWhileIdle" value="true" />
		<!-- 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true -->
		<property name="blockWhenExhausted" value="false" />
	</bean>
	
	<!-- redis单机 通过连接池 -->
	<bean id="jedisPool" class="redis.clients.jedis.JedisPool" destroy-method="close">
		<constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
		<constructor-arg name="host" value="192.168.25.145"/>
		<constructor-arg name="port" value="6379"/>
	</bean>

测试代码:

private ApplicationContext applicationContext;

	@Before
	public void init() {
		applicationContext = new ClassPathXmlApplicationContext(
				"classpath:applicationContext.xml");
	}

	@Test
	public void testJedisPool() {
	JedisPool pool = (JedisPool) applicationContext.getBean("jedisPool");
			try  {
			jedis = pool.getResource();
			
			jedis.set("name", "lisi");
			String name = jedis.get("name");
			System.out.println(name);
		}catch(Exception ex){
			ex.printStackTrace();
		}finally{
			if(jedis != null){
				//关闭连接
				jedis.close();
			}
		}
	}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值