Redis教程,Redis集群搭建与Spring-data-redis的使用(Spring-data-redis使用篇)

JSON 2016-12-23 11:44:38 19194

  Redis教程  ,  Redis  集群搭建系列:

  1. Redis教程,Redis集群搭建与Spring-data-redis的使用(介绍篇)
  2. Redis教程,Redis集群搭建与Spring-data-redis的使用(集群搭建篇)
  3. Redis教程,Redis集群搭建与Spring-data-redis的使用(Spring-data-redis使用篇)

一、使用Spring-data-redis Jar包准备

首先spring-data-redis  需要在1.7 版本以上,附件里有  Mavem  的pom.xml  可以下载其他依赖和测试的时候必要的包。

Maven 引入 Spring-data-redis

<dependency>
	<groupId>org.springframework.data</groupId>
	<artifactId>spring-data-redis</artifactId>
	<version>1.7.5.RELEASE</version>
</dependency>

他会依赖一些包,比如说 spring-data-commons ,在spring-data-x 系列里,都要依赖这个包。如果你之前项目里使用到了spring-data-x 系列的包,可能需要升级,因为都共同依赖了spring-data-commons ,但是在当前集群要使用的spring-data-redis spring-data-commons 必须要1.12.x 版本以上,这个问题要注意一下。

二、Spring-data-redis配置文件配置。

<description>Jedis Cluster Configuration</description>
<!-- 加载配置属性文件 按需加载 -->
<context:property-placeholder
	ignore-unresolvable="true" location="classpath:redis.cluster.properties" />
<!-- 配置Cluster -->
<bean id="redisClusterConfiguration"
	class="org.springframework.data.redis.connection.RedisClusterConfiguration">
	<property name="maxRedirects" value="3"></property>
	<!-- 节点配置 -->
	<property name="clusterNodes">
		<set>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30006"></constructor-arg>
			</bean>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30001"></constructor-arg>
			</bean>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30002"></constructor-arg>
			</bean>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30003"></constructor-arg>
			</bean>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30004"></constructor-arg>
			</bean>
			<bean class="org.springframework.data.redis.connection.RedisClusterNode">
				<constructor-arg name="host" value="192.168.0.201"></constructor-arg>
				<constructor-arg name="port" value="30005"></constructor-arg>
			</bean>
		</set>
	</property>
</bean>
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
	<property name="maxIdle" value="100" />
	<property name="maxTotal" value="600" />
</bean>
<bean id="jeidsConnectionFactory"
	class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
	<constructor-arg ref="redisClusterConfiguration" />
	<constructor-arg ref="jedisPoolConfig" />
</bean>
<!-- redis 访问的模版 -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
	<property name="connectionFactory" ref="jeidsConnectionFactory" />
</bean>

我这里直接写这里了,你也可以写到classpath:redis.cluster.properties 文件中。上面引入了这个文件,没有这个文件会报错。

三、Junit测试Spring-data-redis

1.Junit jar 准备

<dependency>
	<groupId>junit</groupId>
	<artifactId>junit</artifactId>
	<version>4.12</version>
	<scope>test</scope>
</dependency>
<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-test</artifactId>
	<version>4.2.5.RELEASE</version>
	<type>pom</type>
</dependency>

需要一个spring-test 。如果还有问题,看附件里的pom.xml

2.log4j.properties准备

新建一个log4j.properties  文件放到resource 下,内容如下。

log4j.rootLogger=debug,Console

log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

log4j.category.org.apache.commons.beanutils.converters=error

3.Java代码

log4j 支持类:

package test;

import java.io.FileNotFoundException;

import org.junit.runners.model.InitializationError;
import org.springframework.util.Log4jConfigurer;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

public class JUnit4ClassRunner extends SpringJUnit4ClassRunner{
	static {
		try {
			Log4jConfigurer.initLogging("classpath:log4j.properties");
		} catch (FileNotFoundException ex) {
			System.err.println("Cannot Initialize log4j");
		}
	}
	
	public JUnit4ClassRunner(Class<?> clazz) throws InitializationError {
		super(clazz);
	}
}

Junit 测试类:

在这个匿名内部类

package test;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;

@RunWith(JUnit4ClassRunner.class)
// 整合
@ContextConfiguration(locations = "classpath:spring.xml")
// 加载配置
public class TestSDK extends AbstractJUnit4SpringContextTests {

	@Autowired
	RedisTemplate redisTemplate;

	@Test 
	public void testUserInfo() {
		
		redisTemplate.execute(new RedisCallback<Integer>() {
			//这里返回值是个上面的RedisCallback<Integer> 中的泛型一直,
			public Integer doInRedis(RedisConnection connection) {
				int i = 0;
				for (; i < 100; i++) {
					byte[] key = ("key:" + i).getBytes();
					byte[] value = ("value:" + i).getBytes();
					connection.set(key, value);
				}
				//这里返回值是个上面的RedisCallback<Integer> 中的泛型一直,
				return i;
				
			}
		});
		
	}
}

结构如下:

OK了,这个比较简单。


版权所属:SO JSON在线解析

原文地址:https://www.sojson.com/blog/203.html

转载时必须以链接形式注明原始出处及本声明。


附件下载:

备注:点击文件名下载,附件源来自云端,只能在本站下载。复制下载链接无效。

本文主题:

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

关于作者
一个低调而闷骚的男人。
相关文章
Redis教程Redis集群搭建Spring-data-redis使用集群搭建
Redis教程Redis集群搭建Spring-data-redis使用(介绍
SpringBoot 集成Spring-data-redisredis对象序列化存储
Shiro教程(四)Shiro + Redis配置
Linux Centos 使用 Redis service 启动,Redis service 脚本编写
Java Redis线程池ShardedJedisPool 使用方法,Java Jedis连接池的使用
Shiro教程(五)Shiro + Redis实现
Redis与Memcached的比较 ,然后选择了Redis
Redis的理解,Redis是什么,Redis和Memcache谁快?
Redis 密码、端口、ip绑定配置,bat编写运行redis
最新文章
Linux I/O重定向 1767
Ruby 循环 - while、for、until、break、redo 和 retry 711
Node.js:全局对象 517
如何使用终端检查Linux上的内存使用情况 635
JavaScript对象详细剖析 300
Python print() 函数 409
PHP if/else/elseif 语句 407
HTML5 Canvas弧线教程 387
Java赋值运算符 431
XML内部实体和外部实体 464
最热文章
最新MyEclipse8.5注册码,有效期到2020年 (已经更新) 686836
苹果电脑Mac怎么恢复出厂系统?苹果系统怎么重装系统? 675081
免费天气API,天气JSON API,不限次数获取十五天的天气预报 615785
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 611117
Jackson 时间格式化,时间注解 @JsonFormat 用法、时差问题说明 555623
我为什么要选择RabbitMQ ,RabbitMQ简介,各种MQ选型对比 510028
Elasticsearch教程(四) elasticsearch head 插件安装和使用 481399
Jackson 美化输出JSON,优雅的输出JSON数据,格式化输出JSON数据... ... 269208
Java 信任所有SSL证书,HTTPS请求抛错,忽略证书请求完美解决 244787
Elasticsearch教程(一),全程直播(小白级别) 227489
支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

查看我的收藏

正在加载... ...