Java操作Redis需要导入两个jar:
  •   commons-pool2-2.4.2.jar
  •   jedis-2.1.0.jar
package com.chinasofti.test;

import java.io.IOException;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Logger; import org.junit.Before;
import org.junit.Test; import redis.clients.jedis.Jedis; /**
* Java连接Redis测试
* @author liuhl
*
*/
public class ConnRedis { Jedis jedis; @Before
public void init(){
jedis = new Jedis("localhost", 6379, 30);
jedis.auth("admin");
} /**
* 测试Redis对字符串的操作
* set():添加一个新字符串
* append():向已有的key所对应的value上面追加值
* del():删除某个键
* mset():设置多个键值对
* incr(k):对该可以进行+1操作
* @author liuhl
*/
@Test
public void testRedisString(){
jedis.set("username", "sMith kevens");
jedis.append("username", "是Redis开发者");
System.out.println(jedis.get("username")+"------------");
//删除某个键
jedis.del("date");
System.out.println(jedis.get("date")+"======");
//设置多个键值对
jedis.mset("nicheng","shubiao","QAge","3","QQnumber","906058683","sex","man");
jedis.incr("QAge");//进行+1操作
System.out.println(jedis.get("nicheng")+":"+jedis.get("QAge")+":"+jedis.get("QQnumber")+":"+jedis.get("sex"));
} /**
* Redis对List的操作
* llen():获取列表size
* lpush():向列表左侧插入元素
* rpush():向列表右侧插入元素
* lrange("",0,-1):获取列表所有元素
* @author liuhl
*/
@Test
public void testRedisList(){
//开始前先移除所有的内容
jedis.del("javaframe work");
System.out.println(jedis.lrange("java framework", 0, -1));
//定义列表frame work,并向其中添加三条数据
jedis.lpush("javaframe work", "struts2");
jedis.lpush("javaframe work", "spring");
jedis.lpush("javaframe work", "hibernate");
System.out.println(jedis.llen("javaframe work")+"个");
System.out.println(jedis.lrange("javaframe work", 0, -1)); //向列表右侧添加元素
jedis.rpush("javaframe work", "ibatis");
jedis.rpush("javaframe work", "mybatis");
jedis.rpush("javaframe work", "springmvc");
System.out.println(jedis.lrange("javaframe work", 0, -1));
} /**
*Jedis操作无序列表(Set)
*sadd():向无序列表插入元素
*smembers():获取所有加入的value
*srem():移除
*sismember():判断一个值是不是某个集合的元素,返回boolean
*scard():返回集合元素的个数
*srandmember():返回集合中的一个随机元素
*@author liuhl
*@return void
*@category
*/
@Test
public void testRedisSet(){
//向无序集合插入元素
jedis.sadd("user", "yanbao");
jedis.sadd("user", "chengyi");
jedis.sadd("user", "fanwei");
//移除
jedis.srem("user", "chengyi");
System.out.println(jedis.smembers("user"));
System.err.println(jedis.sismember("user", "yunfei"));
System.out.println(jedis.scard("user"));
System.out.println(jedis.srandmember("user"));
} /**
* 测试列表排序sort
* redis:Lists是双向链表
* 排序前先清掉列表,后添加数据测试
* @exception InterruptedException:检查异常
* @author liuhl
*/
@Test
public void testListSort() throws InterruptedException{
jedis.del("arr");
jedis.lpush("arr", "4");
jedis.lpush("arr", "78");
jedis.lpush("arr", "2");
jedis.lpush("arr", "9");
jedis.lpush("arr", "7");
jedis.rpush("arr", "120");
jedis.rpush("arr", "91");
jedis.rpush("arr", "88");
jedis.rpush("arr", "31");
jedis.rpush("arr", "10");
System.out.println("排序前:"+jedis.lrange("arr", 0, -1));
System.out.println("排序后:"+jedis.sort("arr")); } /**
*
* 测试redis有序集合
* com.chinasofti.test
* 方法名:testRedisShortZset
* 创建人:liuhl
* 时间:2017-4-5-上午10:15:33
* return: void
* @exception
* @since 1.0.0
* zadd():向有序集合(sorts zsets)中插入一个元素
* zrange():仅列出所有的元素值。
*/
@Test
public void testRedisShortZset(){
//向有序集合sorts sets插入元素
jedis.zadd("lhlzset", 6, "http://localhost:8080");
jedis.zadd("lhlzset", 6, "sort");
//只列出有序集合的元素
System.out.println(jedis.zrange("lhlzset", 0, -1));
System.out.println(jedis.zrangeByScore("lhlzset", 0, 6)); } /**
*
* 测试hashs哈希
* com.chinasofti.test
* 方法名:testHashs
* 创建人:liuhl
* 时间:2017-4-6-上午9:46:04
* return: void
* @exception
* @since 1.0.0
* hmset():建立hashs并赋值
* hmget():列出hashs相关
*/
@Test
public void testHashs(){
//建立hashs并赋值
Map<String, String> map = new HashMap<>();
map.put("首都", "北京");map.put("河南", "洛阳");map.put("陕西", "西安");
jedis.hmset("china", map);
//列出hashs的内容
System.out.println(jedis.hmget("china", "河南")); }
}
package com.chinasofti.test;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig; /**
* Redis连接池
*
* @author Administrator
*
*/
public class RedisUtils { // Redis服务器IP
private static String ADDR = "127.0.0.1";
// redis端口号
private static int PORT = 6379;
// 访问密码
private static String AUTH = "admin";
/**
* 可用连接实例的最大数目,默认为8,如果赋值为-1,则表示不限制,
* 如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
*/
private static int MAX_ACTIVE = 1024;
// 控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
private static int MAX_IDLE = 200;
// 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
private static int MAX_WAIT = 10000;
private static int TIMEOUT = 10000;
// 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
private static boolean TEST_ON_BORROW = true;
private static JedisPool jedisPool = null;
// 初始化连接池
static {
try {
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxActive(MAX_ACTIVE);
config.setMaxIdle(MAX_IDLE);
// config.setMaxWait(MAX_WAIT);
config.setTestOnBorrow(TEST_ON_BORROW);
// jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
// 注释的这两行为jdk版本问题导致,可忽略
} catch (Exception e) {
e.printStackTrace();
}
} /**
* 获取redis实例
*/
public synchronized static Jedis getJedis() {
try {
if (jedisPool != null) {
Jedis jedis = jedisPool.getResource();
return jedis;
} else {
return null;
}
} catch (Exception e) {
e.printStackTrace();
return null;
}
} /**
*
* @param jedis
*/
public static void returnResource(final Jedis jedis) {
if (jedis != null) {
jedisPool.returnResource(jedis);// 关闭操作已经在此处处理了
}
} }

Java使用Jedis操作Redis大全的更多相关文章

  1. Redis入门和Java利用jedis操作redis

    Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...

  2. Java中Jedis操作Redis与Spring的整合

    Redis是一个key-value存储系统.它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop. ...

  3. Java通过jedis操作redis(增删改查)

    package sgh.main.powersite; import java.util.ArrayList; import java.util.HashMap; import java.util.I ...

  4. Java通过jedis操作redis缓存

    package com.wodexiangce.util; import java.util.Set; import redis.clients.jedis.Jedis; /** * redis工具类 ...

  5. java客户端Jedis操作Redis Sentinel 连接池

    pom配置: <dependency> <groupId>org.springframework.data</groupId> <artifactId> ...

  6. jedis操作redis的几种常见方式总结

    Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...

  7. JAVA中通过Jedis操作Redis连接与插入简单库

    一.简述 JAVA中通过Jedis操作Redis连接与插入简单库 二.依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis ...

  8. Java Spring mvc 操作 Redis 及 Redis 集群

    本文原创,转载请注明:http://www.cnblogs.com/fengzheng/p/5941953.html 关于 Redis 集群搭建可以参考我的另一篇文章 Redis集群搭建与简单使用 R ...

  9. Jedis操作Redis数据库

    添加Maven依赖: <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</grou ...

随机推荐

  1. MHA-Atlas-MySQL高可用集群2

    MHA脚本管理方式 (1)获取管理脚本master_ip_failover 提示:yum安装的manager是没有这个脚本的. 我们需要从manager的源码包里复制一个.   [root@mysql ...

  2. Linux下安装Python3的django并配置mysql作为django默认数据库(转载)

    我的操作系统为centos6.5 1  首先选择django要使用什么数据库.django1.10默认数据库为sqlite3,本人想使用mysql数据库,但为了测试方便顺便要安装一下sqlite开发包 ...

  3. 《大型网站系统与Java中间件实现》有感

    头一次只用了一周的时间就看完一本书<大型网站系统与Java中间件实现>,这本书是关于设计方面的,提到了服务框架,消息中间件,数据访问层,以及如何解决应用之间的调用,解耦,以及应用和存储之间 ...

  4. docker 网络 路由

    通过在Docker宿主机上添加静态路由实现跨宿主机通信 模拟环境 主机1(192.168.58.144) 设置docker0 网关 (172.17.0.1/16)                主机2 ...

  5. SignalR 行实时通信最大连接数

    SignalR 搭建实时刷新应用虽然非常方便,但是有个问题你必须考虑到,就是一般的浏览器,对于SignalR的全双工通信方式,绝大多数浏览器都只支持6个新窗口,如果你打开第7个,那么新的框口页面是不会 ...

  6. MySQL数据库使用规范

    一.建表规约 1.[强制]表达是与否概念的字段,必须使用is_xxx的方式命名,数据类型是unsigned tinyint (1表示是,0表示否) 说明:任何字段如果为非负数,必须是unsigned ...

  7. day02 格式化字符串

    字符格式化2019-04-01 方法一 通过f + {} 格式化字符串 name = input("Name: ")age = input("Age:")sco ...

  8. 多次ajax请求数据json出错!!

    问题描述: 1.对象数据存放在session中,每次从session中取数据 2.jsp初始化完毕调用ajax请求,返回的数据格式出错(返回部分数据,即丢失了部分数据) 解决方案:

  9. http摘要认证

    摘要认证步骤:      1. 客户端访问一个受http摘要认证保护的资源.      2. 服务器返回401状态以及nonce等信息,要求客户端进行认证. HTTP/1.1 401 Unauthor ...

  10. 去freessl.org申请免费ssl服务器证书

    去freessl.org申请免费ssl服务器证书 来源: 本文链接 来自osnosn的博客 写于: 2019-03-30. 想搞个自签名证书,可以参考这篇: 用openssl为WEB服务器生成证书(自 ...