redis学习(十一)
时间:2022-07-24
本文章向大家介绍redis学习(十一),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
监控! Watch
悲观锁:
- 很悲观,认为什么时候都会出问题,无论做什么都会加锁!
乐观锁:
- 很乐观,认为什么时候都不会出问题,所以不会上锁! 更新数据的时候去判断一下,在此期间是否 有人修改过这个数据,
- 获取version
- 更新的时候比较 version
redis监控测试。
# 正常操作。
127.0.0.1:6666> set money 100 # 设置总金额。
OK
127.0.0.1:6666> set out 0 # 已消费金额。
OK
127.0.0.1:6666> watch money # 监控金额。
OK
127.0.0.1:6666> multi # 开启事务。
OK
127.0.0.1:6666> decrby money 20 # 减。
QUEUED
127.0.0.1:6666> incrby out 20 # 加。
QUEUED
127.0.0.1:6666> exec # 执行事务,正常执行。
1) (integer) 80
2) (integer) 20
# 测试多线程修改值 , 使用watch 可以当做redis的乐观锁操作!
127.0.0.1:6666> watch money #监控
OK
127.0.0.1:6666> multi
OK
127.0.0.1:6666> decrby money 10
QUEUED
127.0.0.1:6666> incrby out 10
QUEUED
127.0.0.1:6666> exec # 未执行前,money被另外线程修改。
(error) EXECABORT Transaction discarded because of previous errors.
# 另外线程
[root@centos8 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c91b615aebc1 redis:6.0.5 "docker-entrypoint.s…" 3 days ago Up About an hour 6379/tcp, 0.0.0.0:6666->6666/tcp cxyredis
[root@centos8 ~]# docker exec -it c91b615aebc1 /bin/bash
root@c91b615aebc1:/data# cd /bin
root@c91b615aebc1:/bin# redis-cli -p 6666
127.0.0.1:6666> auth "cxy0809."
OK
127.0.0.1:6666> keys *
1) "out"
2) "money"
127.0.0.1:6666> get money
"80"
127.0.0.1:6666> decrby money 10 # 修改操作。
(integer) 70
# 如果修改失败,获取最新的值就好。
127.0.0.1:6666> unwatch # 解除监控。
OK
127.0.0.1:6666> watch money # 重新监控。
OK
127.0.0.1:6666> multi
OK
127.0.0.1:6666> decrby money 1
QUEUED
127.0.0.1:6666> incrby money 1
QUEUED
127.0.0.1:6666> exec # 执行成功,再没有其他线程打扰到情况下。
1) (integer) 69
2) (integer) 70
- Jexus以.NET(Phalanger)方式支持PHP的网站
- jquery鼠标事件
- Jexus 负载均衡
- 用.NET Framework 2.0创建 Form设计器[翻译]
- jquery事件绑定
- Fontello:免费Web-font 图标大集合(font-face 图标集)
- 通过 wp-config.php 禁止安装、升级或编辑WordPress 主题与插件
- 利用VS2005中的Code Snippets提高开发效率
- 用schemaSpy制作数据库文档
- WordPress 投票插件Post Ratings,可在谷歌搜索显示星级投票(附中文包下载)
- Spark学习笔记——共享变量
- 如何升级Mono
- 使用信息架构视图访问数据库元数据
- Java 基础标识符
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Mysql事物和锁
- PyTorch7:torch.nn.init
- Puppeteer 入门与实战
- 【DB笔试面试854】在Oracle中,删除数据库的方式有哪几种?
- 方差齐性检验
- Windows WSL2 htop打开黑屏的问题解决
- 【DB笔试面试855】在Oracle中,简单说说PSU升级的过程
- HashMap中add()方法的源码学习
- IOC容器实现
- Docker安装mysql
- 【LeeCode 面试题】二叉树的前序遍历,中序遍历,后序遍历递归和迭代的两种实现方式
- MySQL笔记汇总
- 【DB笔试面试856】在Oracle中,如何判定实例是否运行?
- 【DB笔试面试857】在Oracle中,若一个主机上有多个Oracle实例,则如何确定哪些共享内存段属于想要清掉的实例的内存段?
- vue + flask实现邮件密码找回功能