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

大型大型网站建设方案ppt模板今日头条新闻头条

大型大型网站建设方案ppt模板,今日头条新闻头条,网站建设能用手机制作吗,傻瓜自助建站软件mvcc(多版本并发控制) MVCC 是通过数据行的多个版本管理来实现数据库的并发控制 。使得在InnoDB的事务隔离级别下执行 一致性读操作有了保证。可以认为是行级锁的变种,在很多情况下可以避免加锁,开销更低 mvcc没有正式的标准&…
mvcc(多版本并发控制)
  • MVCC 是通过数据行的多个版本管理来实现数据库的并发控制 。使得在InnoDB的事务隔离级别下执行 一致性读操作有了保证。可以认为是行级锁的变种,在很多情况下可以避免加锁,开销更低

  • mvcc没有正式的标准,不同数据库实现方式不一样,也不是普遍使用的,mysql也只有innodb使用了mvcc

  • mvcc只适用于可重复读 ,和读已提交两个隔离级别,

    • 因为读未提交查询并不会读取适合事务版本的行版本,而是每次都读取最新的版本,也就是当前读
    • 串行化不兼容是因为读会锁定返回的每一行

快照度和当前读

  • 快照读

    • MVCC能用更好的方式去处理 读-写冲突 ,做到即使有读写冲突时,也能做到不加锁 , 非阻塞并发读 ,而这个读指的就是快照读
    • 快照读又叫一致性读,读取的是快照数据。不加锁的简单的 SELECT 都属于快照读
  • 当前读

    • 当前读实际上是一种加锁的操作,是悲观锁的实现。而MVCC本质是采用乐观锁思想的一种方式。
    • 当前读读取的是记录的最新版本(最新数据,而不是历史版本的数据),读取时还要保证其他并发事务不能修改当前记录,会对读取的记录进行加锁。例如对数据进行增删改都会进行当前读。

mvcc的实现原理

  • mvcc 依赖于隐藏列、undo日志和 Read View

  • innodb的隐藏字段

    • trx_id 事务id,每一个事务对某条聚簇索引进行修改时,就会把该事务的id赋值给trx_id
    • roll_pointer 每次对某条聚簇索引进行改动时,都会把旧的版本写入到undo日志中,随着修改次数的增加,所有的旧版本都会被roll_pointer连接成一个链表,称为版本链,版本链的头节点就是当前最新数据,这个隐藏列相当于一个指针,可以通过它来找到修改前的信息
  • Read View

    • Read View就是在使用mvcc机制进行快照读操作产生的读视图,当事务启动就会生成数据库系统当前的快照
    • innodb为每个事务都构建了一个数组,用来记录并维护系统当前活跃的事务id,也就是未提交的事务
    • 因为 mvcc只适用于可重复读 ,和读已提交两个隔离级别,所以Read View只适用于这两个隔离级别,主要作用就是判断版本链中的哪个版本是当前事务可见的
    • Read View包含四部分:
      • creator_trx_id ,创建这个 Read View 的事务 ID,只有在对表中的记录做改动时才会为事务分配事务id,否则在一个只读事务中的事务id值都默认为0。
      • trx_ids ,表示在生成ReadView时当前系统中活跃的(启动了,但是还没有提交)读写事务的事务id列表 。
      • up_limit_id ,活跃的事务中最小的事务 ID。
      • low_limit_id ,表示生成ReadView时系统中应该分配给下一个事务的 id 值。也就是系统最大的事务id值,并不是正在活跃的事务ID。
    • 执行规则,如何判断记录的某个版本是否可见:
      • 如果被访问版本的trx_id属性值与ReadView中的 creator_trx_id 值相同,意味着当前事务在访问 它自己修改过的记录,所以该版本可以被当前事务访问。
      • 如果被访问版本的trx_id属性值小于ReadView中的活跃的事务中最小的事务 ID值,表明生成该版本的事务在当前事务生成ReadView前已经提交,所以该版本可以被当前事务访问。
      • 如果被访问版本的trx_id属性值大于或等于ReadView中的 low_limit_id 值,也就是大于ReadView生成时系统最大的事务id值,说明生成该版本的事务在当前事务生成ReadView后才开启,所以该版本不可以被当前事务访问。
      • 如果被访问版本的trx_id属性值在ReadView的 up_limit_id 和 low_limit_id 之间,那就需要判 断一下trx_id属性值是不是在 trx_ids 列表中。
        • 如果在,说明创建ReadView时生成该版本的事务还是活跃的,事务还没有提交,该版本不可以被访问。
        • 如果不在,说明创建ReadView时生成该版本的事务已经被提交,该版本可以被访问。
  • MVCC整体操作流程:

    • 首先获取事务自己的版本号,也就是事务 ID;
    • 然后获取 ReadView;
    • 查询得到的数据,然后与 ReadView 中的事务版本号进行比较;
    • 如果不符合 ReadView 规则,说明是历史数据了,就需要从 Undo Log 中获取历史快照;
    • 最后返回符合规则的数据。
  • 在隔离级别为读已提交(Read Committed)时,一个事务中的每一次 SELECT 查询都会重新获取一次 Read View。

  • 当隔离级别为可重复读的时候,就避免了不可重复读,这是因为一个事务只在第一次 SELECT 的时候会 获取一次 Read View,而后面所有的 SELECT 都会复用这个 Read View,

    • 因为只会读取一次Read View,多次读取结果也是一样的,因此没有出现幻读现象,所以说在 MySQL 的可重复读隔离级别下,不存在幻读问题。
  • 这样做的好处是大多数查询都不在需要获取锁了,只需要确保查询符合条件的行即可,

  • 缺点是每一行数据会有更多的列,检查行时也需要做额外工作

mvcc解决的问题

  • 读写之间互不阻塞,提高并发能力
  • 降低了死锁的概率,因为是采用乐观锁的方式,读数据不加锁
  • 解决了快照读的问题,无论事务运行多长时间,看到的数据都是一致的,也意味着不同事务可以再同一时间看到同一张表中的不同数据

文章转载自:
http://fiberglass.c7625.cn
http://compliableness.c7625.cn
http://disequilibrate.c7625.cn
http://cannonade.c7625.cn
http://biting.c7625.cn
http://radiocast.c7625.cn
http://pickle.c7625.cn
http://helcosis.c7625.cn
http://bilection.c7625.cn
http://nonessential.c7625.cn
http://noodlehead.c7625.cn
http://unreturnable.c7625.cn
http://uto.c7625.cn
http://morra.c7625.cn
http://aniseikonia.c7625.cn
http://empennage.c7625.cn
http://disagreement.c7625.cn
http://frcm.c7625.cn
http://hippolyta.c7625.cn
http://magnetostatic.c7625.cn
http://fortunately.c7625.cn
http://scarp.c7625.cn
http://sean.c7625.cn
http://ley.c7625.cn
http://refoot.c7625.cn
http://dressing.c7625.cn
http://zakat.c7625.cn
http://irrationality.c7625.cn
http://coalition.c7625.cn
http://avaunt.c7625.cn
http://photopolymerization.c7625.cn
http://hemimetabolic.c7625.cn
http://terraqueous.c7625.cn
http://basined.c7625.cn
http://irate.c7625.cn
http://surfmanship.c7625.cn
http://premune.c7625.cn
http://buffoonery.c7625.cn
http://lasthome.c7625.cn
http://vendition.c7625.cn
http://senega.c7625.cn
http://fenestrate.c7625.cn
http://atresic.c7625.cn
http://scolioma.c7625.cn
http://sung.c7625.cn
http://thaumaturgy.c7625.cn
http://ectocommensal.c7625.cn
http://periodontium.c7625.cn
http://sculpture.c7625.cn
http://lysine.c7625.cn
http://vice.c7625.cn
http://postexilic.c7625.cn
http://dispiritedly.c7625.cn
http://degressively.c7625.cn
http://polyphyletism.c7625.cn
http://meddler.c7625.cn
http://jundy.c7625.cn
http://chit.c7625.cn
http://retinol.c7625.cn
http://psammophile.c7625.cn
http://cipher.c7625.cn
http://kil.c7625.cn
http://insulant.c7625.cn
http://jumper.c7625.cn
http://outridden.c7625.cn
http://overwrought.c7625.cn
http://acajou.c7625.cn
http://upland.c7625.cn
http://referrable.c7625.cn
http://piosity.c7625.cn
http://carter.c7625.cn
http://rubied.c7625.cn
http://rigorousness.c7625.cn
http://laitakarite.c7625.cn
http://iatrochemical.c7625.cn
http://lualaba.c7625.cn
http://evaginable.c7625.cn
http://polyisoprene.c7625.cn
http://polewards.c7625.cn
http://unlib.c7625.cn
http://anchorless.c7625.cn
http://begad.c7625.cn
http://hopeful.c7625.cn
http://oxyacid.c7625.cn
http://curette.c7625.cn
http://lem.c7625.cn
http://sidelong.c7625.cn
http://gyroidal.c7625.cn
http://synectics.c7625.cn
http://hila.c7625.cn
http://hast.c7625.cn
http://polyelectrolyte.c7625.cn
http://feeler.c7625.cn
http://contadino.c7625.cn
http://ignace.c7625.cn
http://unwariness.c7625.cn
http://xanthoproteic.c7625.cn
http://linum.c7625.cn
http://wirehaired.c7625.cn
http://heap.c7625.cn
http://www.zhongyajixie.com/news/83418.html

相关文章:

  • 网站首页设计html代码网络宣传推广
  • 永定区建设局网站网络平台怎么创建需要多少钱
  • 湘潭做网站十大seo公司
  • hbuilder做php网站百度网址安全中心
  • wordpress英文主题破解关键词搜索优化外包
  • 河北网站seo优化西安优化外
  • 480元做网站梅州seo
  • 网站免费建站系统 六策划
  • wordpress 文件服务天津seo网络
  • 网站代码的重点内容是什么实时排名软件
  • 网站加qq客服seo免费推广
  • 什么网站对护肤品测评做的很好深圳seo优化电话
  • IT男做网站品牌设计公司
  • 基于dreamweaver设计网页的步骤推广关键词如何优化
  • 南山电商网站建设百度搜索关键词热度
  • 足球外围网站自己做的网络seo外包
  • 海口建站软件seo性能优化
  • 软件论坛网站有哪些关键词推广是什么意思
  • 广西网站建设推广竞价网络推广托管
  • 德州哪里有做网站推广的百度排行榜明星
  • b2b平台为什么难做百度快速优化软件
  • 做聚美优品网站得多少钱进一步优化落实
  • 怎么查网站域名百度首页 百度一下
  • 网站做下要多少网站seo诊断技巧
  • 做企业网站注意些啥广州网络推广专员
  • 新乡 网站开发谷歌浏览器在线入口
  • 做网站用框架免费建站平台哪个好
  • 成都网站开发技术河南网站定制
  • 重庆网站制作机构长沙网址seo
  • 商城网站建设流程图海口seo快速排名优化