印趣云课堂-网校系统服务商

手机APP

微信公众号

nginx - Redis 事务理解 云课堂问答

概念理解

redis 事务的作用:
1.保证被事务包含的命令要么全部执行,要么全部不执行(注意:在执行事务的过程中遇到错误可能会导致有些命令不能执行).
2.保证被事务包含的命令执行时不被打断.

对于第二点来说,于任何客户端来说启用多线程来执行被事务包含的代码没多大效果;因为
redis是一个进程(没有多线程),也就是说执行体只有一个;同时又因为事务的存在,同一时刻只有一个事务在执行(事务包含命令没有并行执行),所以说客户端通过多线程方式执行被redis事务包含的命令作用不大;同时也说明被事务包含的代码可以防止资源的竞争.

伪代码说明

`
for i = 0 ; i < 3 ; i++ {

 newThread.doTaskBackground(doTransTask);

}

doTransTask() {

MULTI;// other commands set key1  value1 EXEC;  

}

`
以上是自己的理解,有错误的地方还请指出. 如果您有什么心得也可以告知与我.谢谢!

提问者郑海玲

添加回答

2回答
艾艾
6年前艾艾

讲一下我的理解:
redis有事物,但无原子性
multi初始化了一个命令队列,使该事物的命令以线性存储,
在redis中,对于一个存在问题的命令,如果在入队的时候就已经出错,整个事务内的命令将都不会被执行(其后续的命令依然可以入队),如果这个错误命令在入队的时候并没有报错,而是在执行的时候出错了,那么redis默认跳过这个命令执行后续命令。也就是说,redis只实现了部分事务;
一般认为在传统的关系型数据中,只要有任意一条指令失败,则整个事务都会被rollback,而在redis的事物中,中间的某条指令的失败不会导致前面已做指令rollback,也不会造成后续的指令不做。

赞同00个回复
liangqx
6年前liangqx

redis事务其实就是按顺序打包运行命令,所以你上面第一条是不成立的,中间有指令失败,还是会执行前面的指令,所以没有回滚,也不存在要么全部不执行。
第二点是成立的,在事务执行过程中,其他命令是阻塞状态,等待事务指令全部完成才继续。

赞同00个回复

相关问题

相关分类

    请选择你的考试意向可选择1个考试 随时调整

    test

    外语考试

    考研学历

    教师公考

    医药卫生

    职业资格

    财会经济

    建筑工程

    趣味测试

    考研

    IT

    医疗教学

    外语教学

    数理逻辑

    文学

    点击查看更多考试 >

    选好了