Redis官方推荐使用Jedis api,但它是不完善的。
ps:由于我本人以前学习技术都是照着图片打代码,这样的学习效果不佳,所以在本文章中我会尽量使用文字阐述,但仍会尽量详尽,目的在于让各位看客多思考,遇到问题然后解决问题才有更好的学习效果。
Jedis使用
首先我们使用IDEA创建一个新的Maven project,在pom文件中添加下面的依赖:
<dependencies>
<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.0.1</version>
</dependency>
<!-- Junit测试依赖 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
新建Class,简单代码如下:
public class TestJedis {
public static void main(String[] args) {
Jedis jedis = new Jedis("127.0.0.1",6379); //这里应该填入自己的Redis服务器主机ip
System.out.println("连接对象:"+jedis);
//jedis.set("username","LangYun");
System.out.println(jedis.get("username"));
jedis.close();
}
}
在此代码的基础上我们还可以进行优化,比如:
- 把配置信息:主机ip、端口等等放入配置文件(自己实现)
- 将jedis.close()放入finally里面,整体采用try-catch-finally结构
稍作优化后的代码(使用RedisPool):
public class TestRedisPool {
public static void main(String[] args) {
//1.设置连接池的配置对象
JedisPoolConfig config = new JedisPoolConfig();
//2.设置连接池参数
config.setMaxTotal(30);
//3.最大空闲
config.setMaxIdle(10);
//4.获取连接池对象
JedisPool jedisPool = new JedisPool(config, "127.0.0.1", 6379);
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
//5.设置数据
/*jedis.set("nametest","LangYun");*/
String name = jedis.get("nametest");
System.out.println("name="+name);
}catch (Exception e){
e.printStackTrace();
}finally {
if (jedis != null){
jedis.close();
}
//虚拟机关闭的时候释放资源
if (jedisPool != null){
jedisPool.close();
}
}
}
}
SpringDataRedis
新建maven项目,建议使用如图的项目结构
在pom文件中添加下面的依赖:
<!-- 集中定义依赖版本号 -->
<properties>
<spring.version>4.2.4.RELEASE</spring.version>
</properties>
<dependencies>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.9</version>
</dependency>
<!-- 缓存相关 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.8.1</version>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>1.7.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-nop</artifactId>
<version>1.7.2</version>
</dependency>
</dependencies>
新建resources/properties/redis-config.properties配置文件
redis-config.properties
#Redis settings
#server IP
redis.host=xxx.xxx.xxx.xxx
#server port
redis.port=6379
#server pass
redis.pass=
#use dbIndex
redis.database=0
#控制一个pool最多有多少个状态为idle(空闲的)的jedis实例
redis.maxIdle=300
#表示当borrow(引入)一个jedis实例时,最大的等待时间,如果超过等待时间(毫秒),则直接抛出JedisConnectionException
redis.maxWaitMillis=3000
#在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的
redis.testOnBorrow=true
新建resources/spring/applicationContext-redis.xml文件
applicationContext-redis.xml
<?xml version="1.0" encoding="utf-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 加载properties文件 -->
<context:property-placeholder location="classpath*:properties/*.properties"/>
<!-- redis 相关配置 -->
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxIdle" value="${redis.maxIdle}"/>
<property name="maxWaitMillis" value="${redis.maxWaitMillis}"/>
<property name="testOnBorrow" value="${redis.testOnBorrow}"/>
</bean>
<!-- Jedis连接工厂 -->
<bean id="JedisConnectionFactory"
class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
p:hostName="${redis.host}" p:port="${redis.port}" p:password="${redis.pass}" p:poolConfig-ref="poolConfig"/>
<!-- redisTemplate类 负责操作Redis服务器封装工具类 -->
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
<property name="connectionFactory" ref="JedisConnectionFactory"/>
</bean>
</beans>
示例代码:
package com.cloud.test;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(value = "classpath:spring/applicationContext-redis.xml")
public class TestRedisTemplate {
@Autowired
RedisTemplate redisTemplate;
@Test
public void testSetString(){
redisTemplate.boundValueOps("name").set("LangYun");
}
@Test
public void testGetString(){
System.out.println(redisTemplate.boundValueOps("name").get());
}
@Test
public void deleteKey(){
redisTemplate.delete("name");
}
}
两者对比
Redis的客户端有两种实现方式,一是可以直接调用Jedis来实现,二是可以使用Spring Data Redis,通过Spring的封装来调用,如何选择要根据实际情况。
Spring Data Redis优点:
- 对具体Redis客户端做了封装,客户端可在Jedis、Jredis、Rjc等客户端中做出选择和切换。
- 用template对调用做了封装,省去了建立连接,释放连接等繁琐代码。
- 对对象的序列化也可自由选择工具。
- 提供对Spring Cache的支持,可用注解实现Cache,但是无法设定缓存失效时间。
Jedis优点
- 可用到Jedis本身提供的更多的特性,比如Sharded,比如Masater/Slaver。
常见问题
- 连接超时。解决方法:检查端口是否开启,如果是云服务器,就要在控制台中添加安全组其中授权对象ip设置喂0.0.0.0/0即为对所有人开发,同时还要在服务器中开放对应端口。然后重启redis服务。
- 不要手打spring约束文件,容易出错,建议直接复制。