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

求个网站知乎如何做网页赚钱

求个网站知乎,如何做网页赚钱,adsl做网站,怎么做网店网站作为关系型数据库中一项非常重要的基础功能——事务#xff0c;在 Redis 中是如何处理并使用的#xff1f; 1.前言 事务指的是提供一种将多个命令打包#xff0c;一次性按顺序地执行的机制#xff0c;并且保证服务器只有在执行完事务中的所有命令后#xff0c;才会继续处… 作为关系型数据库中一项非常重要的基础功能——事务在 Redis 中是如何处理并使用的 1.前言 事务指的是提供一种将多个命令打包一次性按顺序地执行的机制并且保证服务器只有在执行完事务中的所有命令后才会继续处理此客户端的其他命令。 事务也是其他关系型数据库所必备的一项非常重要的能力。以支付的场景为例正常情况下只有正常消费完成之后才会减去账户余额。但如果没有事务的保障可能会发生消费失败了但依旧会把账户的余额给扣减了我想这种情况应该任何人都无法接受吧所以事务是关系型数据库中一项非常重要的基础功能。 2.事务基本使用 事务在其他语言中一般分为以下三个阶段 开启事务——Begin Transaction执行业务代码提交事务——Common Transaction业务处理中出现异常回滚事务——Rollback Transaction 以 Java 中的事务执行为例 // 开启事务 begin(); try {//......// 提交事务commit(); } catch(Exception e) {// 回滚事务rollback(); }Redis 中的事务从开始到结束也是要经历三个阶段 开启事务命令入列执行事务/放弃事务 其中开启事务使用 multi 命令事务执行使用 exec 命令放弃事务使用 discard 命令。 1开启事务 multi 命令用于开启事务实现代码如下 multi OKmulti 命令可以让客户端从非事务模式状态变为事务模式状态如下图所示 注意multi 命令不能嵌套使用如果已经开启了事务的情况下再执行 multi 命令会提示如下错误 (error) ERR MULTI calls can not be nested 执行效果如下代码所示 127.0.0.1:6379 multi OK 127.0.0.1:6379 multi (error) ERR MULTI calls can not be nested当客户端是非事务状态时使用 multi 命令客户端会返回结果 OK 如果客户端已经是事务状态再执行 multi 命令会 multi 命令不能嵌套的错误但不会终止客户端为事务的状态如下图所示 2命令入列 客户端进入事务状态之后执行的所有常规 Redis 操作命令非触发事务执行或放弃和导致入列异常的命令会依次入列命令入列成功后会返回 QUEUED 如下代码所示 multi OKset k v QUEUEDget k QUEUED执行流程如下图所示 注意命令会按照先进先出FIFO的顺序出入列也就是说事务会按照命令的入列顺序从前往后依次执行。 3执行事务/放弃事务 执行事务的命令是 exec 放弃事务的命令是 discard 。 执行事务示例代码如下 multi OKset k v2 QUEUEDexec 1) OKget k v2放弃事务示例代码如下 multi OKset k v3 QUEUEDdiscard OKget k v2执行流程如下图所示 3.事务错误回滚 事务执行中的错误分为以下三类 执行时才会出现的错误简称执行时错误入列时错误不会终止整个事务入列时错误会终止整个事务。 1执行时错误 示例代码如下 get k vmulti OKset k v2 QUEUEDexpire k 10s QUEUEDexec 1) OK 2) (error) ERR value is not an integer or out of rangeget k v2执行命令解释如下图所示 从以上结果可以看出即使事务队列中某个命令在执行期间发生了错误事务也会继续执行直到事务队列中所有命令执行完成。 2入列错误不会导致事务结束 示例代码如下 get k vmulti OKset k v2 QUEUEDmulti (error) ERR MULTI calls can not be nestedexec 1) OKget k v2执行命令解释如下图所示 可以看出重复执行 multi 会导致入列错误但不会终止事务最终查询的结果是事务执行成功了。除了重复执行 multi 命令还有在事务状态下执行 watch 也是同样的效果下文会详细讲解关于 watch 的内容。 3入列错误会导致事务结束 示例代码如下 get k v2multi OKset k v3 QUEUEDset k (error) ERR wrong number of arguments for set commandexec (error) EXECABORT Transaction discarded because of previous errors.get k v2执行命令解释如下图所示 4为什么不支持事务回滚 Redis 官方文档的解释如下 If you have a relational databases background, the fact that Redis commands can fail during a transaction, but still Redis will execute the rest of the transaction instead of rolling back, may look odd to you. However there are good opinions for this behavior: Redis commands can fail only if called with a wrong syntax (and the problem is not detectable during the command queueing), or against keys holding the wrong data type: this means that in practical terms a failing command is the result of a programming errors, and a kind of error that is very likely to be detected during development, and not in production.Redis is internally simplified and faster because it does not need the ability to roll back. An argument against Redis point of view is that bugs happen, however it should be noted that in general the roll back does not save you from programming errors. For instance if a query increments a key by 2 instead of 1, or increments the wrong key, there is no way for a rollback mechanism to help. Given that no one can save the programmer from his or her errors, and that the kind of errors required for a Redis command to fail are unlikely to enter in production, we selected the simpler and faster approach of not supporting roll backs on errors. 大概的意思是作者不支持事务回滚的原因有以下两个 他认为 Redis 事务的执行时错误通常都是编程错误造成的这种错误通常只会出现在开发环境中而很少会在实际的生产环境中出现所以他认为没有必要为 Redis 开发事务回滚功能不支持事务回滚是因为这种复杂的功能和 Redis 追求的简单高效的设计主旨不符合。 这里不支持事务回滚指的是不支持运行时错误的事务回滚。 4.监控 watch 命令用于客户端并发情况下为事务提供一个乐观锁CASCheck And Set也就是可以用 watch 命令来监控一个或多个变量如果在事务的过程中某个监控项被修改了那么整个事务就会终止执行。 watch 基本语法如下 watch key [key …] watch 示例代码如下 watch k OKmulti OKset k v2 QUEUEDexec (nil)get k v从以上命令可以看出如果 exec 返回的结果是 nil 时表示 watch 监控的对象在事务执行的过程中被修改了。从 get k 的结果也可以看出在事务中设置的值 set k v2 并未正常执行。 执行流程如下图所示 注意 watch 命令只能在客户端开启事务之前执行在事务中执行 watch 命令会引发错误但不会造成整个事务失败如下代码所示 multi OKset k v3 QUEUEDwatch k (error) ERR WATCH inside MULTI is not allowedexec 1) OKget k v3执行命令解释如下图所示 unwatch 命令用于清除所有之前监控的所有对象键值对。 unwatch 示例如下所示 set k v OKwatch k OKmulti OKunwatch QUEUEDset k v2 QUEUEDexec 1) OK 2) OKget k v2可以看出即使在事务的执行过程中k 值被修改了因为调用了 unwatch 命令整个事务依然会顺利执行。 5.事务在程序中使用 以下是事务在 Java 中的使用代码如下 import redis.clients.jedis.Jedis; import redis.clients.jedis.Transaction;public class TransactionExample {public static void main(String[] args) {// 创建 Redis 连接Jedis jedis new Jedis(xxx.xxx.xxx.xxx, 6379);// 设置 Redis 密码jedis.auth(xxx);// 设置键值jedis.set(k, v);// 开启监视 watchjedis.watch(k);// 开始事务Transaction tx jedis.multi();// 命令入列tx.set(k, v2);// 执行事务tx.exec();System.out.println(jedis.get(k));jedis.close();} }6.小结 事务为多个命令提供一次性按顺序执行的机制与 Redis 事务相关的命令有以下五个 multi开启事务exec执行事务discard丢弃事务watch为事务提供乐观锁实现unwatch取消监控取消事务中的乐观锁 正常情况下 Redis 事务分为三个阶段开启事务、命令入列、执行事务。Redis 事务并不支持运行时错误的事务回滚但在某些入列错误如 set key 或者是 watch 监控项被修改时提供整个事务回滚的功能。 7.思考题 Redis 事务中如何解决并发修改的问题Redis 支持事务回滚吗使用 Redis 事务时会出现哪三种错误这三种错误对事务有何影响只有高手才能答对的问题你能答上来几个 8.参考鸣谢 https://redis.io/topics/transactions https://redisbook.readthedocs.io/en/latest/feature/transaction.html#id3 关注下方二维码订阅更多精彩内容
http://www.sadfv.cn/news/71425/

相关文章:

  • 岳阳市交通建设投资公司门户网站wap网站什么意思
  • 网站建设使用情况二级域名免费网站怎么申请
  • 临沂市建设工程监理公司网站网站建设 ipv6
  • 中小企业网站功能模块及数据库表东莞建筑公司都有哪些
  • 有可以做ssgsea的网站么新郑网站建设
  • 网站建设与电子商务的教案2手房产App网站开发
  • 网站轮播广告动画怎么做的网站正在建设中网页
  • 还能用的wap网站做宣传图册在什么网站
  • 重庆建网站优化网站太卡怎么优化
  • 做类似电影天堂的网站违法吗上海房产网二手房出售信息
  • 建网站手机工程造价信息网官网信息价
  • 做网站初级教程网站建设犭金手指C排名15
  • 可以在哪些网站 app做推广的网站博客模板
  • 网站定制生成器网站建设授权书
  • 外贸网站推广平台排名前十名wordpress品牌分类
  • 做网站还赚钱吗英文网站推广方法
  • 盐城网站开发渠道合作重庆腊肠制作
  • 打造网站品牌wps网站超链接怎么做
  • 青岛开发区制作网站公司app制作培训
  • 做网站前怎么建立数据结构网站建设有哪些模块
  • 电子商务网站建设与管理是什么网站架构怎么看
  • 戴尔官方网站建设启示网站开发需要考什么证
  • 网站如何做关键词引流市场调研报告ppt模板
  • 阿里云服务器可以访问国外网站吗浏览器怎么打开网站服务器连接
  • 免费网站制作 优帮云网站后台这么做
  • python快速搭建网站集团公司门户网站建设
  • 注册网站做推广wordpress 阅后即
  • 付网站建设费用计入科目wordpress登录没链接
  • 杭州电商网站平台开发公司Wordpress点金
  • 网站所有权变更淘宝运营培训内容