测试联通

创建Maven工程,引入依赖

  1. <dependency>
  2. <groupId>redis.clients</groupId>
  3. <artifactId>jedis</artifactId>
  4. <version>2.1.0</version>
  5. </dependency>
  1. package com.lun.shang;
  2. import redis.clients.jedis.Jedis;
  3. public class TestPing {
  4. public static void main(String[] args) {
  5. Jedis jedis = new Jedis("127.0.0.1",6379);
  6. //输出PONG,redis连通成功
  7. System.out.println(jedis.ping());
  8. }
  9. }

Jedis_常用API

  1. import java.util.HashMap;
  2. import java.util.Iterator;
  3. import java.util.List;
  4. import java.util.Map;
  5. import java.util.Set;
  6. import redis.clients.jedis.Jedis;
  7. public class TestAPI {
  8. public static void main(String[] args) {
  9. Jedis jedis = new Jedis("127.0.0.1", 6379);
  10. // key
  11. Set<String> keys = jedis.keys("*");
  12. for (Iterator iterator = keys.iterator(); iterator.hasNext();) {
  13. String key = (String) iterator.next();
  14. System.out.println(key);
  15. }
  16. System.out.println("jedis.exists====>" + jedis.exists("k2"));
  17. System.out.println(jedis.ttl("k1"));
  18. // String
  19. // jedis.append("k1","myreids");
  20. System.out.println(jedis.get("k1"));
  21. jedis.set("k4", "k4_redis");
  22. System.out.println("----------------------------------------");
  23. jedis.mset("str1", "v1", "str2", "v2", "str3", "v3");
  24. System.out.println(jedis.mget("str1", "str2", "str3"));
  25. // list
  26. System.out.println("----------------------------------------");
  27. // jedis.lpush("mylist","v1","v2","v3","v4","v5");
  28. List<String> list = jedis.lrange("mylist", 0, -1);
  29. for (String element : list) {
  30. System.out.println(element);
  31. }
  32. // set
  33. jedis.sadd("orders", "jd001");
  34. jedis.sadd("orders", "jd002");
  35. jedis.sadd("orders", "jd003");
  36. Set<String> set1 = jedis.smembers("orders");
  37. for (Iterator iterator = set1.iterator(); iterator.hasNext();) {
  38. String string = (String) iterator.next();
  39. System.out.println(string);
  40. }
  41. jedis.srem("orders", "jd002");
  42. System.out.println(jedis.smembers("orders").size());
  43. // hash
  44. jedis.hset("hash1", "userName", "lisi");
  45. System.out.println(jedis.hget("hash1", "userName"));
  46. Map<String, String> map = new HashMap<String, String>();
  47. map.put("telphone", "13811814763");
  48. map.put("address", "atguigu");
  49. map.put("email", "abc@163.com");
  50. jedis.hmset("hash2", map);
  51. List<String> result = jedis.hmget("hash2", "telphone", "email");
  52. for (String element : result) {
  53. System.out.println(element);
  54. }
  55. // zset
  56. jedis.zadd("zset01", 60d, "v1");
  57. jedis.zadd("zset01", 70d, "v2");
  58. jedis.zadd("zset01", 80d, "v3");
  59. jedis.zadd("zset01", 90d, "v4");
  60. Set<String> s1 = jedis.zrange("zset01", 0, -1);
  61. for (Iterator iterator = s1.iterator(); iterator.hasNext();) {
  62. String string = (String) iterator.next();
  63. System.out.println(string);
  64. }
  65. }
  66. }

事务

  1. import redis.clients.jedis.Jedis;
  2. import redis.clients.jedis.Transaction;
  3. public class TestTX {
  4. public boolean transMethod() throws InterruptedException {
  5. Jedis jedis = new Jedis("127.0.0.1", 6379);
  6. int balance;// 可用余额
  7. int debt;// 欠额
  8. int amtToSubtract = 10;// 实刷额度
  9. jedis.watch("balance");
  10. // jedis.set("balance","5");//此句不该出现,讲课方便。模拟其他程序已经修改了该条目
  11. Thread.sleep(7000);
  12. balance = Integer.parseInt(jedis.get("balance"));
  13. if (balance < amtToSubtract) {
  14. jedis.unwatch();
  15. System.out.println("modify");
  16. return false;
  17. } else {
  18. System.out.println("***********transaction");
  19. Transaction transaction = jedis.multi();
  20. transaction.decrBy("balance", amtToSubtract);
  21. transaction.incrBy("debt", amtToSubtract);
  22. transaction.exec();
  23. balance = Integer.parseInt(jedis.get("balance"));
  24. debt = Integer.parseInt(jedis.get("debt"));
  25. System.out.println("*******" + balance);
  26. System.out.println("*******" + debt);
  27. return true;
  28. }
  29. }
  30. /**
  31. * 通俗点讲,watch命令就是标记一个键,如果标记了一个键, 在提交事务前如果该键被别人修改过,那事务就会失败,这种情况通常可以在程序中 重新再尝试一次。
  32. * 首先标记了键balance,然后检查余额是否足够,不足就取消标记,并不做扣减; 足够的话,就启动事务进行更新操作,
  33. * 如果在此期间键balance被其它人修改, 那在提交事务(执行exec)时就会报错, 程序中通常可以捕获这类错误再重新执行一次,直到成功。
  34. *
  35. * @throws InterruptedException
  36. */
  37. public static void main(String[] args) throws InterruptedException {
  38. TestTX test = new TestTX();
  39. boolean retValue = test.transMethod();
  40. System.out.println("main retValue-------: " + retValue);
  41. }
  42. }

主从复制

  1. import redis.clients.jedis.Jedis;
  2. public class TestMS {
  3. public static void main(String[] args) {
  4. Jedis jedis_M = new Jedis("127.0.0.1", 6379);
  5. Jedis jedis_S = new Jedis("127.0.0.1", 6380);
  6. jedis_S.slaveof("127.0.0.1", 6379);
  7. jedis_M.set("class", "1122V2");
  8. String result = jedis_S.get("class");//可能有延迟,需再次启动才能使用
  9. System.out.println(result);
  10. }
  11. }

JedisPool

  • 获取Jedis实例需要从JedisPool中获取
  • 用完Jedis实例需要返还给JedisPool
  • 如果Jedis在使用过程中出错,则也需要还给JedisPool
  1. import redis.clients.jedis.Jedis;
  2. import redis.clients.jedis.JedisPool;
  3. import redis.clients.jedis.JedisPoolConfig;
  4. public class JedisPoolUtil {
  5. private static volatile JedisPool jedisPool = null;
  6. private JedisPoolUtil() {
  7. }
  8. public static JedisPool getJedisPoolInstance() {
  9. if (null == jedisPool) {
  10. synchronized (JedisPoolUtil.class) {
  11. if (null == jedisPool) {
  12. JedisPoolConfig poolConfig = new JedisPoolConfig();
  13. poolConfig.setMaxActive(1000);
  14. poolConfig.setMaxIdle(32);
  15. poolConfig.setMaxWait(100 * 1000);
  16. poolConfig.setTestOnBorrow(true);
  17. jedisPool = new JedisPool(poolConfig, "127.0.0.1", 6379);
  18. }
  19. }
  20. }
  21. return jedisPool;
  22. }
  23. public static void release(JedisPool jedisPool, Jedis jedis) {
  24. if (null != jedis) {
  25. jedisPool.returnResourceObject(jedis);
  26. }
  27. }
  28. }
  1. import redis.clients.jedis.Jedis;
  2. import redis.clients.jedis.JedisPool;
  3. public class TestPool {
  4. public static void main(String[] args) {
  5. JedisPool jedisPool = JedisPoolUtil.getJedisPoolInstance();
  6. JedisPool jedisPool2 = JedisPoolUtil.getJedisPoolInstance();
  7. System.out.println(jedisPool == jedisPool2);
  8. Jedis jedis = null;
  9. try {
  10. jedis = jedisPool.getResource();
  11. jedis.set("aa", "bb");
  12. } catch (Exception e) {
  13. e.printStackTrace();
  14. } finally {
  15. JedisPoolUtil.release(jedisPool, jedis);
  16. }
  17. }
  18. }

配置总结

JedisPool的配置参数大部分是由JedisPoolConfig的对应项来赋值的。

  • maxActive:控制一个pool可分配多少个jedis实例,通过pool.getResource()来获取;如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted。
  • maxIdle:控制一个pool最多有多少个状态为idle(空闲)的jedis实例;
  • whenExhaustedAction:表示当pool中的jedis实例都被allocated完时,pool要采取的操作;默认有三种。
    • WHEN_EXHAUSTED_FAIL --> 表示无jedis实例时,直接抛出NoSuchElementException;
    • WHEN_EXHAUSTED_BLOCK --> 则表示阻塞住,或者达到maxWait时抛出JedisConnectionException;
    • WHEN_EXHAUSTED_GROW --> 则表示新建一个jedis实例,也就说设置的maxActive无用;
  • maxWait:表示当borrow一个jedis实例时,最大的等待时间,如果超过等待时间,则直接抛JedisConnectionException;
  • testOnBorrow:获得一个jedis实例的时候是否检查连接可用性(ping());如果为true,则得到的jedis实例均是可用的;
  • testOnReturn:return 一个jedis实例给pool时,是否检查连接可用性(ping());
  • testWhileIdle:如果为true,表示有一个idle object evitor线程对idle object进行扫描,如果validate失败,此object会被从pool中drop掉;这一项只有在timeBetweenEvictionRunsMillis大于0时才有意义;
  • timeBetweenEvictionRunsMillis:表示idle object evitor两次扫描之间要sleep的毫秒数;
  • numTestsPerEvictionRun:表示idle object evitor每次扫描的最多的对象数;minEvictableIdleTimeMillis
  • minEvictableIdleTimeMillis:表示一个对象至少停留在idle状态的最短时间,然后才能被idle object evitor扫描
  • 并驱逐;这一项只有在timeBetweenEvictionRunsMillis大于0时才有意义;
  • softMinEvictableIdleTimeMillis:在minEvictableIdleTimeMillis基础上,加入了至少minIdle个对象已经在pool里面了。如果为-1,evicted不会根据idle time驱逐任何对象。如果minEvictableIdleTimeMillis>0,则此项设置无意义,且只有在timeBetweenEvictionRunsMillis大于0时才有意义;
  • lifo:borrowObject返回对象时,是采用DEFAULT_LIFO(last in first out,即类似cache的最频繁使用队列),如果为False,则表示FIFO队列;

RedisTemplate

Jedis是Redis官方推荐的面向Java的操作Redis的客户端,而RedisTemplate是SpringDataRedis中对JedisApi的高度封装。

SpringDataRedis相对于Jedis来说可以方便地更换Redis的Java客户端,比Jedis多了自动管理连接池的特性,方便与其他Spring框架搭配使用

  1. @Autowired
  2. private RedisTemplate<String,String> template;

redis的基本操作

操作 Jedis StringRedisTemplate
String
设置 set("k","v") template.opsForValue().set("k","v")
获取 get("k") template.opsForValue().get("k")
增1 incr("k") template.boundValueOps("k").increment(1)
减1 decr("k") template.boundValueOps("k").increment(-1)
设置时间 setex("k",seconds,"v") template.opsForValue().set("k","v",20, TimeUnit.SECONDS)
不存在 就设置 setnx("k","v") template.opsForValue().setIfAbsent("k", "v")
获取过期时间 ttl("k") template.getExpire("k")
删除 del("k") template.delete("k")
Hash
设置 jedis.hset("pig","name","peiqi"; template.opsForHash().put("pig","name","peiqi")
获取 jedis.hget("pig","name") template.opsForHash().get("pig", "name") 获取所有template.opsForHash().values("pig")
删除 jedis.hdel("pig","name") template.opsForHash().delete("pig","name")
判断是否存在 jedis.hexists("pig","name") template.opsForHash().hasKey("pig","name")
List 左/右不做区分
添加 rpush("k","v") template.opsForList().rightPush("k","v")
移出 rpop("list") template.opsForList().rightPop("k")
长度 llen("k") template.opsForList().size("k")
获取 lrange("list",0,-1) //-1全部 template.opsForList().range("list", 0, -1)
Set
添加 sadd("k","v") template.opsForSet().add("k","v")
值移除 srem("k","v") template.opsForSet().remove("k","v")
直接移 spop("k") template.opsForSet().pop("k")
长度 scard("k") template.opsForSet().size("k")
交集 sinter("k1","k2" ) template.opsForSet().intersect("k", "k2")
并集 sunion("k1","k2" ) template.opsForSet().union("k", "k2")
差集 sdiff("k1","k2" ) template.opsForSet().difference("k", "k2")
Zset
增加 zadd("k",1,"a") template.opsForZSet().add("k","aa",12)
排名结果 zrevrange("k", 0, -1) template.opsForZSet().reverseRange("k", 0, -1)
排名分数 zrevrangeByScoreWithScores("k", 12, 10); template.opsForZSet().reverseRangeByScore("k", 1, 100)
修改分数 zincrby("k",20,"a") template.opsForZSet().incrementScore("k","aa",19)
数量 zcard("k") template.opsForZSet().zCard("k")
获取排名 zrank("k","a") template.opsForZSet().rank("k","aa")

Java连接redis之Jedis使用的更多相关文章

  1. java连接redis使用jedis带密码

    一.引入jedis的Maven配置文件 <!-- redis连接客户端jedis --> <dependency> <groupId>redis.clients&l ...

  2. java连接Redis初始化jedis失败!

    Bean instantiation via constructor failed; nested exception is org.springframework.beans.BeanInstant ...

  3. Java连接redis的使用演示样例

    Java连接redis的使用演示样例 Redis是开源的key-value存储工具,redis通经常使用来存储结构化的数据,由于redis的key能够包括String.hash.listset和sor ...

  4. java 连接redis 以及基本操作

    一.首先下载安装redis 二.项目搭建 1.搭建一个maven 工程 2. 在pom.xml文件的dependencies节点下增加如下内容: <!-- resis --> <de ...

  5. java对于Redis中jedis的操作

    package com.answer.redis; import java.util.HashMap; import java.util.List; import java.util.Map; imp ...

  6. 【redis数据库学习】用JAVA连接redis数据库各种报错

    最近项目中,需要用到redis数据库,然后使用Jedis让JAVA连接redis. 首先,安装redis数据库,参考的是:http://www.runoob.com/redis/redis-insta ...

  7. java 连接 Redis

    使用 jedis-2.9.0.jar 包 连接 Docker 中的 Redis 容器. package redisTest; /** * @Author:YangLianjun * @Descript ...

  8. Java连接Redis,存储对象获取对象()byte和json),连接池

    Java连接Redis Jedis连接Redis,Lettuce连接Redis Jedis连接Redis 1. 创建maven项目 2. 引入依赖 <dependencies> <d ...

  9. Java操作redis客户端Jedis连接集群(Cluster)

    创建JedisCluster类连接redis集群. @Test public void testJedisCluster() throws Exception { //创建一连接,JedisClust ...

随机推荐

  1. Windows下升级Python3.7.7后(原Python3.6.2版本)如何切换Python版本

    笔者:风起怨江南 出处:https://www.cnblogs.com/mengjinxiang 笔者原创,文章欢迎转载,如果喜欢请点赞+关注,谢谢! 问题:window系统下,如果升级了最新的Pyt ...

  2. python学习笔记(八)-模块

    大型python程序以模块和包的形式组织.python标准库中包含大量的模块.一个python文件就是一个模块.1.标准模块 python自带的,不需要你安装的2.第三方模块 需要安装,别人提供的. ...

  3. 检验appium环境是否正常:使用appium自动给手机安装app(注意:如果已存在该app,再执行会将原来的卸载再重装,需谨慎)

    (注意:如果已存在该app,再执行会将原来的卸载再重装.泪的教训,我的微信被卸载重装了o(╥﹏╥)o,自动安装app这个步骤需谨慎操作) hi,前面几篇已经讲了appium环境的搭建.设备的连接, 那 ...

  4. Hive——安装以及概述

    一.hive的安装 注意:安装hive的前提要安装好MySQL和Hadoop Hadoop安装:https://www.cnblogs.com/lmandcc/p/15306163.html MySQ ...

  5. 疏忽Bug

    仅供自己留存备份   错误: vector不是模板 解决: 头文件未包含 头文件: #include <vector> using namespace std;     错误: 多字节字符 ...

  6. UOJ#454-[UER #8]打雪仗【通信题】

    正题 题目链接:https://uoj.ac/problem/454 题目大意 \(Alice\)有一个长度为\(2n\)的\(01\)串,\(Bob\)有\(n\)个在\([1,2n]\)位置的下标 ...

  7. CF960G-Bandit Blues【第一类斯特林数,分治,NTT】

    正题 题目链接:https://www.luogu.com.cn/problem/CF960G 题目大意 求有多少个长度为\(n\)的排列,使得有\(A\)个前缀最大值和\(B\)个后缀最大值. \( ...

  8. 使用VisualStudioCode开发Vue

    前言 本文主要介绍在VisualStudioCode下开发Vue. Nodejs.Npm.Vue的项目搭建参考下面文章. 用后台开发的逻辑理念学习VUE 在Windows下学习Nodejs.Npm和V ...

  9. 这两个基础seo插件,wordpress网站必装

    WordPress对搜索引擎非常友好,这一点很多人都知道.不过我们在制作完成WordPress主题后,还可以在原来的良好基础上,添加两个队seo非常有利的WordPress插件. 第一个插件:Baid ...

  10. Vue组件间的数据传输

    1.父组件向子组件传输数据:自定义属性 1 //父组件 2 <Son :msg="message" :user="userinfo"></So ...