java中使用redis和spring中调用redis

1.需要的jar包,配置的pom.xml文件

		<!-- redis缓存 -->
		<dependency>
				<groupId>redis.clients</groupId>
				<artifactId>jedis</artifactId>
                                <version>2.7.2</version>
		</dependency>

2.java调用

/**     
 * @文件名称: JedisTest.java   
 * @描述: TODO  
 * @作者:  wuwh
 * @时间:2018年2月7日 下午1:52:33  
 * @版本:V1.0     
 */ 
package com.taotao.test;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

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

/**  
 * @类功能说明:    
 * @作者: wuwh
 * @创建时间:2018年2月7日 下午1:52:33  
 * @版本:V1.0  
 */
public class JedisTest {

	/**  
	 * 方法功能说明:    测试单个的redis
	 * @参数:       
	 * @return void     
	 * @throws  
	 */ 
	@Test
	public void testJedisSingle() {
		//创建一个jedis的对象。
		Jedis jedis = new Jedis("192.168.200.128", 6379);
		//调用jedis对象的方法,方法名称和redis的命令一致。
	//	jedis.set("userNmae", "wenhao");
		String string = jedis.get("userName");
		System.out.println(string);
		//关闭jedis。
		jedis.close();
	}
	
	/**
	 * 使用连接池
	 */
	@Test
	public void testJedisPool() {
		//创建jedis连接池
		JedisPool pool = new JedisPool("192.168.200.128", 6379);
		//从连接池中获得Jedis对象
		Jedis jedis = pool.getResource();
		String string = jedis.get("userName");
		System.out.println(string);
		//关闭jedis对象
		jedis.close();
		pool.close();
	}
	

	/**  
	 * 方法功能说明:    单机版测试,与spring整合
	 * @参数:       
	 * @return void     
	 * @throws  
	 */ 
	@Test
	public void testSpringJedisSingle() {
		ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*.xml");
		JedisPool pool = (JedisPool) applicationContext.getBean("redisClient");
		Jedis jedis = pool.getResource();
		String string = jedis.get("userName");
		System.out.println(string);
		jedis.close();
		pool.close();
	}
	
	/**  
	 * 方法功能说明:    集群版测试,与spring整合
	 * @参数:       
	 * @return void     
	 * @throws  
	 */ 
	@Test
	public void testSpringJedisCluster() {
		ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*.xml");
		JedisCluster jedisCluster =  (JedisCluster) applicationContext.getBean("redisClient");
		String string = jedisCluster.get("userName");
		System.out.println(string);
		jedisCluster.close();
	}
}

3.结合spring使用的配置文件applicationContext-jedis.xml

<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
	http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
	http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
	http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
<!-- 连接池配置 -->
	<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>	
	<!-- jedis客户端单机版 -->
	<bean id="redisClient" class="redis.clients.jedis.JedisPool">
		<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
		<constructor-arg name="port" value="6379"></constructor-arg>
		<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
	</bean>
	<bean id="jedisClientSingle" class="com.taotao.rest.dao.impl.JedisClientSingle" />
	<!-- jedis客户端集群版 :在项目部署时,再决定是否启用集群版,在开发时使用的单机版-->
	<!-- <bean id="redisClient" class="redis.clients.jedis.JedisCluster">
		<constructor-arg name="nodes">
			<set>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7001"></constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7002"></constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7003"></constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7004"></constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7005"></constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.200.128"></constructor-arg>
					<constructor-arg name="port" value="7006"></constructor-arg>
				</bean>
			</set>
		</constructor-arg>
		<constructor-arg name="poolConfig" ref="jedisPoolConfig"></constructor-arg>
		<bean id="jedisClientCluster" class="com.taotao.rest.dao.impl.JedisClientCluster" />
	</bean> -->
</beans>


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 生成唯一的 Redis 键可以使用 RedisTemplate 的 execute 方法和 Redis 的 INCR 命令。以下是一个生成唯一键的示例代码: ``` import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.ValueOperations; import java.util.concurrent.TimeUnit; public class UniqueKeyGenerator { private final RedisTemplate<String, Long> redisTemplate; private final ValueOperations<String, Long> valueOps; public UniqueKeyGenerator(RedisTemplate<String, Long> redisTemplate) { this.redisTemplate = redisTemplate; this.valueOps = redisTemplate.opsForValue(); } public String generateKey(String keyPrefix) { Long counter = redisTemplate.execute(connection -> { byte[] keyBytes = redisTemplate.getKeySerializer().serialize(keyPrefix); byte[] valueBytes = connection.incr(keyBytes); return redisTemplate.getValueSerializer().deserialize(valueBytes); }); String uniqueKey = String.format("%s:%d", keyPrefix, counter); return uniqueKey; } } ``` 在上面的示例代码,我们首先定义了一个 RedisTemplate 对象和一个 ValueOperations 对象。然后,我们定义了一个 generateKey 方法,该方法接受一个键名前缀作为参数,并返回生成的唯一键。 在 generateKey 方法,我们使用 RedisTemplate 的 execute 方法来执行 Redis 的 INCR 命令。INCR 命令会将指定的键的值加上 1,并返回新的值。因此,我们可以利用这个特性来生成唯一的键。 在 execute 方法的回调函数,我们首先将键名前缀序列化为字节数组,然后使用 Redis 连接对象的 incr 方法执行 INCR 命令,并将返回的新值序列化为字节数组。最后,我们使用 RedisTemplate 的 getValueSerializer 方法将字节数组反序列化为 Long 类型的计数器值。 接着,我们将键名前缀和计数器值拼接起来,生成唯一的键名,并返回给调用者。 请注意,以上示例代码生成的键名并不是全局唯一的,因为计数器是在 Redis 自增的,如果多个客户端同时执行上述代码,可能会生成相同的键名。如果需要生成全局唯一的键名,可以考虑使用 UUID 或其他全局唯一的标识符来作为键名的后缀。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值