本篇内容主要讲解“Jedis使用Redis事务的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Jedis使用Redis事务的方法是什么”吧!
什么是Jedis 是Redis官方推荐的java连接开发工具!使用Java操作Redis 中间件!(就是一个jar包)如果你要使用java操作redis,那么一定要对Jedis十分的熟悉!
1、导入对应的依赖
<!-- 导入jedis的包 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>4.2.2</version>
</dependency>
<!-- fastjson-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.50</version>
</dependency>
2、编码测试
连接redis数据库
操作命令
断开连接!
public class TestPing {
public static void main(String[] args) {
//1、new Jedis对象即可
Jedis jedis = new Jedis("127.0.0.1",6379);
//Jedis所有的命令就是我们之前学习的指令!
System.out.println(jedis.ping());;
}
}
输出:说明连接成功
PONG
jedis所有方法和redis里的所有命令一模一样,没有任何改变,在redis上能操作的,使用jedis同样可以操作
执行结果:
string的其他方法:
执行结果:
执行结果:
执行结果:
也是一样,在linux上执行的命令就是jedis的方法
所有的api命令,就是我们学习的指令,一一对应,一个都没有变化!
1、在java中使用redis的事务:
package com.uno;
import com.alibaba.fastjson.JSONObject;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction;
public class TestTx {
public static void main(String[] args) {
Jedis jedis = new Jedis("127.0.0.1", 6379);
JSONObject jsonObject = new JSONObject();
jsonObject.put("hello","world");
jsonObject.put("name", "UNO");
String result = jsonObject.toJSONString();
//1、开启事务
Transaction multi = jedis.multi();
//jedis.watch(result); //加乐观锁,监视
try {
//2、命令入队
multi.set("user1", result);
multi.set("user2",result);
//3、执行,这三个步骤也都是和linux中操作redis命令一模一样
multi.exec();
} catch (Exception e) {
//当出现错误,放弃事务
multi.discard();
throw new RuntimeException(e);
} finally {
System.out.println(jedis.get("user1"));
System.out.println(jedis.get("user2"));
//关闭连接
jedis.close();
}
}
}
执行结果:成功
{"name":"UNO","hello":"world"}
{"name":"UNO","hello":"world"}
2、如果出现错误:
package com.uno;
import com.alibaba.fastjson.JSONObject;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction;
public class TestTx {
public static void main(String[] args) {
Jedis jedis = new Jedis("127.0.0.1", 6379);
jedis.flushDB(); //先清理一下数据库,免得被上面的代码在redis设置的值影响
JSONObject jsonObject = new JSONObject();
jsonObject.put("hello","world");
jsonObject.put("name", "UNO");
String result = jsonObject.toJSONString();
//1、开启事务
Transaction multi = jedis.multi();
// jedis.watch(result); //加乐观锁,监视
try {
//2、命令入队
multi.set("user1", result);
multi.set("user2",result);
int i = 1/0; //手动设置一个运行时异常,看是不是会出现运行时异常,然后被catch捕获
//3、执行,这三个步骤也都是和linux中操作redis命令一模一样
multi.exec();
} catch (Exception e) {
//放弃事务
multi.discard();
throw new RuntimeException(e);
} finally {
System.out.println(jedis.get("user1"));
System.out.println(jedis.get("user2"));
//关闭连接
jedis.close();
}
}
}
执行结果:出现运行时异常,被catch捕获,在catch中放弃事务,就是都不执行
null
null
Exception in thread "main" java.lang.RuntimeException: java.lang.ArithmeticException: / by zero
at com.uno.TestTx.main(TestTx.java:28)
Caused by: java.lang.ArithmeticException: / by zero
at com.uno.TestTx.main(TestTx.java:22)
注意事项:jedis连不上远程服务器
用Jedis连接阿里云等服务器上的redis
一. 配置redis.conf
1.设置访问redis的密码:requirepass 要设置密码
2.注释bind 127.0.0.1
(重启redis-server服务,进入redis后要先验证密码,用这个命令:auth 密码 ,然后ping一下看有没有配置成功)
二 . idea访问时添加auth密码
Jedis jedis = new Jedis("服务器的外网ip",6379);
jedis.auth("redis的密码");
System.out.println(jedis.ping());
(输出PONG的话就成功了)
到此,相信大家对“Jedis使用Redis事务的方法是什么”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://blog.csdn.net/dayuiicghaid/article/details/125680456