Java 操作Redis

一、 使用Java操作Redis前,请先运行Redis服务与下载Redis驱动,以maven工程为例,引入如下jar

<dependency>
	<groupId>redis.clients</groupId>
	<artifactId>jedis</artifactId>
        <version>2.9.0</version>
</dependency>

创建测试类,验证是否成功连接

public static void main(String[] args) {
	    //设置IP与端口,连接 Redis 服务
	    Jedis jedis = new Jedis("127.0.0.1",6379);
	    //设置 密码
	    jedis.auth("1D9JJ9JIJ0003E4710AC0000596F1A72");
	    //查看服务是否运行,打出pong表示OK
	    System.out.println("connection is OK==========>: "+jedis.ping());
	    String name = jedis.get("admin");
	    System.out.println("姓名:" + name);
	    String noticeVal = jedis.hget("notice", "admin");
	    System.out.println("通知结果:" + noticeVal);
}

执行成功,结果如下

connection is OK==========>: PONG
姓名:null
通知结果:0

二、连接池管理Redis连接,引入redis.properties配置文件

# Redis settings
# 最大闲置数
redis.maxIdle=30
# 最小闲置数
redis.minIdle=10
# 最大连接数
redis.maxTotal=100
# redis服务器的IP地址
redis.url=127.0.0.1
# redis端口
redis.port=6379
# redis密码
redis.password=1D9JJ9JIJ0003E4710AC0000596F1A72
# 超时时间
redis.timeout=2000

编写工具类RedisUtil

package com.util;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

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

/**
 * RedisUtil工具类
 * 
 * @author Administrator
 *
 */

public final class RedisUtil {

	private static final Log logger = LogFactory.getLog(RedisUtil.class);

	private static JedisPool jedisPool = null;

	/**
	 * 初始化Redis连接池
	 */
	static {
		try {
			// 加载配置文件
			InputStream in = RedisUtil.class.getClassLoader().getResourceAsStream("redis.properties");
			Properties pro = new Properties();
			try {
				pro.load(in);
			} catch (IOException e) {
				e.printStackTrace();
			}
			// 获得池子对象
			JedisPoolConfig poolConfig = new JedisPoolConfig();
			poolConfig.setMaxIdle(Integer.parseInt(pro.get("redis.maxIdle")
					.toString()));// 最大闲置个数
			poolConfig.setMinIdle(Integer.parseInt(pro.get("redis.minIdle")
					.toString()));// 最小闲置个数
			poolConfig.setMaxTotal(Integer.parseInt(pro.get("redis.maxTotal")
					.toString()));// 最大连接数
			jedisPool = new JedisPool(poolConfig, pro.getProperty("redis.url"),
					Integer.parseInt(pro.getProperty("redis.port")),
					Integer.parseInt(pro.getProperty("redis.timeout")),
					pro.getProperty("redis.password"));
		} catch (Exception e) {
			logger.error("异常错误", e);
		}
	}

	/**
	 * 获取Jedis实例
	 * 
	 * @return
	 */
	public synchronized static Jedis getJedis() {
		try {
			if (jedisPool != null) {
				Jedis resource = jedisPool.getResource();
				return resource;
			} else {
				return null;
			}
		} catch (Exception e) {
			e.printStackTrace();
			return null;
		}
	}

	/**
	 * 释放jedis资源
	 * 
	 * @param jedis
	 */
	public static void returnResource(final Jedis jedis) {
		if (jedis != null) {
			jedis.close();
		}
	} 
}

测试

public static void main(String[] args) {
		Jedis jedis = RedisUtil.getJedis();
		String result = jedis.set("admin", "管理员");
		System.out.println("结果:" + result);
		//释放资源
		RedisUtil.returnResource(jedis);
	}
结果:OK

使用RedisDesktopManager可视化工具查看

其他数据类型如hash(哈希)、list(列表)、set(集合)及zset(有序集合)的增删改查操作和redis原生指令大同小异,抽取为通用工具类。

我来评几句
登录后评论

已发表评论数()

相关站点

+订阅
热门文章