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

衢州网站建设兼职seo如何进行优化

衢州网站建设兼职,seo如何进行优化,南宁做网页推广有哪些公司,南京谁做免费网站文章目录 前言一、概述二、Redis事务使用1.正常执行事务2.取消事务3.编译型异常4.运行时异常(1/0)5.清空数据库6.监控1.乐观锁正常执行成功2.多线程 总结 前言 Redis事务本质:一组命令的集合!一个事务中的所有命令都会被序列化&a…

文章目录

  • 前言
  • 一、概述
  • 二、Redis事务使用
    • 1.正常执行事务
    • 2.取消事务
    • 3.编译型异常
    • 4.运行时异常(1/0)
    • 5.清空数据库
    • 6.监控
      • 1.乐观锁正常执行成功
      • 2.多线程
  • 总结


前言

Redis事务本质:一组命令的集合!一个事务中的所有命令都会被序列化,在事务执行过程中,会按照顺序执行!一次性、顺序性、排他性!执行一些列的命令。

-------队列 set set set 执行-------


一、概述

Redis事务本质:一组命令的集合!

Redis事务没有隔离性概念!

所有的命令在事务中,并没有直接被执行!只有发起执行命令的时候才会执行!Exec

Redis单条命令式保存原子性的,但是事务不保证原子性!

redis事务的三个阶段:

  • 开启事务(multi)
  • 命令入队(…)
  • 执行事务(exec)

二、Redis事务使用

1.正常执行事务

127.0.0.1:6379> multi  # 开启事务
OK
## 命令入队
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> get k2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> exec # 执行事务
OK
OK
"v2"
OK

2.取消事务

127.0.0.1:6379> multi  #开启事务
OK
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> set k4 v4
QUEUED
127.0.0.1:6379(TX)> discard  #取消事务
OK
127.0.0.1:6379> get k4  #事务中的命令都不会被执行
(nil)

3.编译型异常

即代码有问题!命令有错!事务中所有的命令都不会被执行!

127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> getset k3  #错误的命令
(error) ERR wrong number of arguments for 'getset' command
127.0.0.1:6379(TX)> set k4 v4
QUEUED
127.0.0.1:6379(TX)> set k5 v5
QUEUED
127.0.0.1:6379(TX)> exec  #执行事务报错!
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get k5  #所有的命令都不会被执行!
(nil)

4.运行时异常(1/0)

如果事务队列中存在语法型错误,那么执行命令的时候,其他命令是可以正常执行的,错误命令抛出异常。

127.0.0.1:6379> set k1 "v1"
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> incr k1  #会执行的时候失败
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> get k3
QUEUED
127.0.0.1:6379(TX)> exec
1) (error) ERR value is not an integer or out of range  #虽然第一条命令报错了,但是依旧正常执行成功了!
2) OK
3) OK
4) "v3"
127.0.0.1:6379> get k2
"v2"
127.0.0.1:6379> get k3
"v3"

5.清空数据库

flushdb命令只会清除当前数据库中的数据,而不会影响其他数据库
flushall会清除Redis实例所有数据库(0-15)的缓存数据,执行时候需要小心

flushdb
flushall

在这里插入图片描述

6.监控

watch(乐观锁实现)

  • 悲观锁
    悲观锁(Pessimistic Lock),顾名思义,就是很悲观。
    认为什么时候都会出问题,无论做什么都会加锁!
    每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁。
    这样别人想拿到这个数据就会 block 直到它拿到锁。
    传统的关系型数据库里面就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在操作之前先上锁。

  • 乐观锁
    乐观锁(Optimistic Lock),顾名思义,就是很乐观。
    认为什么时候都不会出问题,所以不会上锁!
    但是在更新的时候会判断一下再此期间别人有没有去更新这个数据,可以使用版本号等机制。(即获取version,更新的时候比较version)
    乐观锁适用于多读的应用类型,这样可以提高吞吐量。
    乐观锁策略:提交版本必须大于记录当前版本才能执行更新。

1.乐观锁正常执行成功

127.0.0.1:6379> set money 100
OK
127.0.0.1:6379> set out 0
OK
127.0.0.1:6379> watch money  #监视money对象
OK
127.0.0.1:6379> multi  #事务正常结束,数据期间没有发生变动,这个时候就正常执行成功
OK
127.0.0.1:6379(TX)> decrby money 20
QUEUED
127.0.0.1:6379(TX)> incrby out 20
QUEUED
127.0.0.1:6379(TX)> exec
1) (integer) 80
2) (integer) 20

2.多线程

使用watch可以当做redis的乐观锁操作
线程1

127.0.0.1:6379> watch money  #监视 money
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> decrby money 10
QUEUED
127.0.0.1:6379(TX)> incrby out 10
QUEUED

线程2

127.0.0.1:6379> get money
"80"
127.0.0.1:6379> set money 1000
OK

此时在线程1中输入exec会发现事务提交失败

127.0.0.1:6379(TX)> exec #执行之前,另外一个线程,修改了我们的值,这个时候,就会导致事务执行失败
(nil)

如果修改失败,获取最新的值就好。

在这里插入图片描述


总结

以上就是Redis事务的相关操作,Redis的乐观锁可以实现秒杀系统。

http://www.hrbkazy.com/news/39447.html

相关文章:

  • 小米网站建设案例360推广平台登录入口
  • 首页调用网站栏目idseo数据监控平台
  • 网站建设哪家强2023近期舆情热点事件
  • 怎样做微网站深圳网站建设公司官网
  • 老网站删除做新站会影响收录吗seo企业推广案例
  • 电子商务网站建设的核心教育培训班
  • 北京网站建设的服务域名注册服务网站哪个好
  • 网站制作 昆明b站推广网站入口
  • 网站开发毕业论文重庆网络推广外包
  • java做网站核心关键词如何优化
  • 企业做网站的公司上海培训机构有哪些
  • 网站的备用金怎么做凭证西安seo学院
  • 愿意做cps的网站鄂州seo
  • 源码交易平台网站源码最近新闻摘抄
  • c2c网站名称和网址百度推广案例及效果
  • 彩票网站开发www.udan英文seo实战派
  • 免费好用的云电脑陕西优化疫情防控措施
  • 专做ppt的网站洛阳seo博客
  • 无网站做网赚网络营销服务的特点有哪些
  • wordpress 高级如何优化网站首页
  • 怎么可以自己制作网站最大的搜索网站排名
  • 做最优秀的自己演讲视频网站百度指数如何提升
  • 网页设计师联盟seo每日
  • 建筑装饰装修seo引擎优化培训
  • 网站怎么优化seo网络推广公司有多少家
  • 医学ppt模板下载免费seo自然排名优化
  • 北京做网站费用关键词小说
  • 徐州集团网站建设多少钱网站如何推广出去
  • 猎聘网招聘电商seo
  • 深圳微商城网站设计顾问