当前位置: 首页 > news >正文

jedis:使用事务开启watch监控

前言

redis中的事务其实就是 :一段指令

redis单条命令的原子性的,而事务不保证原子性

redis事务中所有的命令都会被序列化,执行顺序:谁先进谁先执行

redis事务的三个特性:一次性、顺序性、排他性

redis事务中没有隔离级别概念:所有的命令在事务中,并没有直接执行,只有发起执行的时候才会执行

乐观锁:只会在更新的时候去判断,期间是否有人修改过version

1.导入依赖

<dependencies>
    <!--jedis-->
    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>3.2.0</version>
    </dependency>
    <!--fastjson-->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.62</version>
    </dependency>
</dependencies>

maven仓库: https://mvnrepository.com

2.创建一个User实体类

package dao;

public class userDao {
    
    /**
    * 用户id
    */
    private long userId;
    
    /**
    * 用户姓名
    */
    private String userName;
    
    /**
    * 用户年龄
    */
    private Integer age;
    /**
     * 0中性 1男 2女
     * */
    private Integer sex;
    
        public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public long getUserId() {
        return userId;
    }

    public void setUserId(long userId) {
        this.userId = userId;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public Integer getSex() {
        return sex;
    }

    public void setSex(Integer sex) {
        this.sex = sex;
    }

    public userDao() {
    }

    public userDao(long userId, String userName, Integer age, Integer sex) {
        this.userId = userId;
        this.userName = userName;
        this.age = age;
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "userDao{" +
                "userId=" + userId +
                ", userName='" + userName + '\'' +
                ", age=" + age +
                ", sex=" + sex +
                '}';
    }
}

3.提交事务并获取数据

public static void main(String[] args) {
    //user对象1
    userDao user1 = new userDao();
    user1.setUserId(Long.valueOf("1"));
    user1.setUserName("一只小狐狸OvO");
    user1.setAge(18);
    user1.setSex(1);
    //user对象2
    userDao user2 = new userDao();
    user2.setUserId(Long.valueOf("2"));
    user2.setUserName("凉拌小狐狸OvO");
    user2.setAge(16);
    user2.setSex(2);
    // 1. new jsedis 对象
    // jedis里面存放了全部的指令,具体的指令用途可以去redis的官方文档里面看
    // Redis中文帮助手册:https://www.redis.net.cn/order/
    // 地址是云Redis地址,到期日期是:2025-09-20 大家都可以使用
    Jedis jedis = new Jedis("114.115.208.175",6379);
    // 清除数据 为了下面模拟
    jedis.flushDB();
    //开启事务
    Transaction multi =  jedis.multi();
    try{
        multi.set("user_data_key:userId:"+user1.getUserId(),toJsonString(user1));
        multi.set("user_data_key:userId:"+user2.getUserId(),toJsonString(user2));
        //提交事务
        multi.exec();
    }catch (Exception e){
        //放弃事务 事务中的所有命令都不会执行
        multi.discard();
        //抛出异常
        e.printStackTrace();
    }finally {
        	// mget:批量获取
            List<String> redisGetList = jedis.mget("user_data_key:userId:"+user1.getUserId(),"user_data_key:userId:"+user2.getUserId());
        	//输出从redis中拿到的数据
            System.out.println(redisGetList);
            //关闭事务
            jedis.close();
        }
}
 /**
     * 将对象转成json字符串
     * */
    public static String toJsonString(Object object){
        return JSONObject.toJSONString(object);
    }

    /**
     * 将jsonString转换成Obj
     * */
    public static Object toStringObj(String jsonString,Class Objclass){
        return JSONObject.parseObject(jsonString,Objclass);
    }

5.Redis乐观锁:watch监控

当watch检测到数据变动的时候,此时watch失效,可以使用unwatch取消监视,再重新监视值,开启事务。(需要在多线程的情况下)

    public static void main(String[] args) {
        // new jsedis 对象
        Jedis jedis = new Jedis("114.115.208.175",6379);
        // 清除数据 为了下面模拟
        jedis.flushDB();
        // set 一个监控的数据
        jedis.set("user_data_key:userAge","18");
        // 乐观锁·监控 userAge
        jedis.watch("user_data_key:userAge");
        //开启事务
        Transaction multi =  jedis.multi();
        try{
            //步长 将userAge+1
            multi.incrBy("user_data_key:userAge",1);
            //提交事务
            multi.exec();
        }catch (Exception e){
            // 提交事务可能会遇到运行时异常
            multi.discard();
            //抛出异常
            e.printStackTrace();
        }finally {
            //关闭事务
            jedis.close();
        }
    }

相关文章:

  • 【趣学算法】第一章 算法之美(上)
  • 以MapBox为核心构建Vue地图组件库教程
  • Web链接测试如何做?
  • 【不是问题的问题】为什么复位中断服务程序里面直接调用的main函数,难道所有程序都在复位中断里面执行的?
  • 【ViT 微调时关于position embedding如何插值(interpolate)的详解】
  • 动态内存管理(malloc free calloc realloc)
  • C语言/C++内存管理
  • 【FPGA】什么是串行通信?
  • c语言必背100代码,C语言代码大全(c语言必背项目代码)
  • JavaEE——No.2 套接字编程(TCP)
  • MacOS(M1)交叉编译安卓版本OpenCV(附带FFmpeg)
  • LSTM -长短期记忆网络(RNN循环神经网络)
  • 【老生谈算法】matlab实现频谱分析算法源码——频谱分析
  • Python013--爬虫01(工具准备)
  • 有营养的算法笔记五
  • 【mysql】环境安装、服务启动、密码设置
  • Brief introduction of how to 'Call, Apply and Bind'
  • Hibernate最全面试题
  • JAVA SE 6 GC调优笔记
  • Java到底能干嘛?
  • java架构面试锦集:开源框架+并发+数据结构+大企必备面试题
  • js ES6 求数组的交集,并集,还有差集
  • Mysql5.6主从复制
  • Octave 入门
  • ReactNative开发常用的三方模块
  • Vue 2.3、2.4 知识点小结
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • vue自定义指令实现v-tap插件
  • WePY 在小程序性能调优上做出的探究
  • 阿里云购买磁盘后挂载
  • 基于Volley网络库实现加载多种网络图片(包括GIF动态图片、圆形图片、普通图片)...
  • 看完九篇字体系列的文章,你还觉得我是在说字体?
  • 使用docker-compose进行多节点部署
  • 通过来模仿稀土掘金个人页面的布局来学习使用CoordinatorLayout
  • 用Node EJS写一个爬虫脚本每天定时给心爱的她发一封暖心邮件
  • 走向全栈之MongoDB的使用
  • mysql面试题分组并合并列
  • Prometheus VS InfluxDB
  • 说说我为什么看好Spring Cloud Alibaba
  • ​业务双活的数据切换思路设计(下)
  • (AngularJS)Angular 控制器之间通信初探
  • (C#)获取字符编码的类
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (Matlab)遗传算法优化的BP神经网络实现回归预测
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (八)五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (附源码)springboot 基于HTML5的个人网页的网站设计与实现 毕业设计 031623
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (蓝桥杯每日一题)love
  • (转)自己动手搭建Nginx+memcache+xdebug+php运行环境绿色版 For windows版
  • .[hudsonL@cock.li].mkp勒索病毒数据怎么处理|数据解密恢复
  • .CSS-hover 的解释
  • .net core 连接数据库,通过数据库生成Modell
  • .Net6支持的操作系统版本(.net8已来,你还在用.netframework4.5吗)