mvcc是怎么实现无锁的,网上全都是说读视图,但是就算有读视图,也要先去读取数据行的事务ID,如果这个事务ID可见,那么这个数据行可见,但是其他并发写可能会改变这个数据行啊,读操作还是可能读到一个中间结果,这怎么解决,求佬解惑

全部评论
mvcc解决的是快照读。利用多版本控制执行的。也就是说修改操作并不是直接在原来上面修改。因为要保持老版本。利用undo log日志。
mvcc这里指的是数据库的上层,不会像当前读那样锁住表的一行。数据库具体的底层实现跟这些关系不大,可能用的是cas也可能用的是mutex。具体实现估计要看源码。
mvcc实现读不阻塞写,写不阻塞读,写依然阻塞写,读阻塞读。
会不会我在写的时候先申请一片内存写入新数据,最后把新数据的回滚指针指向老数据
mvcc不是无锁的,只是一种思想,读写互不阻塞,实现分mvocc,mv2pl等,想要具体了解去看论文
只要保证rollptr和tra index原子修改即可 正在修改的数据当前读是看不到的
我怎么感觉没懂通你这个描述呢
可以理解简单,一个修改操作提交会放入到链头,而且在他之前的快照读事务,读取到的链中的数据。
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
11-04 22:03
武汉理工大学 Java
菜菜菜小白菜菜菜:我在字节实习了四个月,有转正的压力所以周末大部分也在公司自学,也是因为一些原因转正拖的很久,这个点还没答辩,过段时间才回去答辩。整个不确定性的焦虑贯穿了我的秋招三个月,我也曾经犹豫过是不是应该放弃转正走秋招更快,最后因为沉没成本一直舍不得放弃,前前后后七个月真的挺累的,尤其是没有来字节实习的同学已经校招拿到意向时更加焦虑。这段时间也跟mentor聊了很多次,他告诉我未来工作上或者生活上,比这些更头疼的事情会更多,关键还是要调整好自己的心态。转正没有通过从过程上来看其实跟你自身没太大的关系,拖了三个月不出结果显然是ld的问题,并且今年美团最近的开奖大家似乎都不是很乐观,所以不去也罢。我在字节实习的时候,6月份有一个赶上春招末期的25届同事刚面进来,也拿到了小sp的薪水。不要对这件事有太大的压力,时代的问题罢了 点赞 评论 收藏
分享
