목차
编辑本段说明
编辑本段比锁定的优势
编辑本段GBase8的特性
데이터 베이스 MySQL 튜토리얼 MySQL MVCC实现及其机制_MySQL

MySQL MVCC实现及其机制_MySQL

Jun 01, 2016 pm 01:51 PM
저장

Multi-Version Concurrency Control 多版本并发控制  

大多数的MySQL事务型存储引擎,如InnoDB,Falcon以及PBXT都不使用一种简单的行锁机制。

事实上,他们都和和另外一种用来增加并发性的被称为“多版本并发控制(MVCC)”的机制来一直使用。

MVCC不只使用在MySQL中,Oracle,PostgreSQL以及其他一些数据为系统也同样使用它。   

你可将将MVCC看成行级别锁的一种妥协,它在许多情况下避免了使用锁,同时可以提供更小的开销。

根据实现的不同,它可以允许非阻塞式读,在写操作进行时只锁定必要的记录。   

MVCC会保存某个时间点上的数据快照。

这意味阒事务可以看到一个一致的数据视图,不管他们需要跑多久。

这同时也意味着不同的事务在同一个时间点看到的同一个表的数据可能是不同的。

如果你从来没有过种体验的话,可能理解起来比较抽象,但是随着慢慢地熟悉这种理解将会很容易。   

各个存储引擎对于MVCC的实现各不相同。

这些不同中的一些包括乐观和悲观并发控制。

我们将通过一个简化的InnoDB版本的行为来展示MVCC工作的一个侧面。   

InnoDB:通过为每一行记录添加两个额外的隐藏的值来实现MVCC,这两个值一个记录这行数据何时被创建,另外一个记录这行数据何时过期(或者被删除)。但是InnoDB并不存储这些事件发生时的实际时间,相反它只存储这些事件发生时的系统版本号。这是一个随着事务的创建而不断增长的数字。每个事务在事务开始时会记录它自己的系统版本号。每个查询必须去检查每行数据的版本号与事务的版本号是否相同。让我们来看看当隔离级别是REPEATABLE READ时这种策略是如何应用到特定的操作的:   SELECT InnoDB必须每行数据来保证它符合两个条件:   

1、InnoDB必须找到一个行的版本,它至少要和事务的版本一样老(也即它的版本号不大于事务的版本号)。这保证了不管是事务开始之前,或者事务创建时,或者修改了这行数据的时候,这行数据是存在的。   

2、这行数据的删除版本必须是未定义的或者比事务版本要大。这可以保证在事务开始之前这行数据没有被删除。   

符合这两个条件的行可能会被当作查询结果而返回。   

INSERT:InnoDB为这个新行记录当前的系统版本号。   

DELETE:InnoDB将当前的系统版本号设置为这一行的删除ID。   

UPDATE:InnoDB会写一个这行数据的新拷贝,这个拷贝的版本为当前的系统版本号。

它同时也会将这个版本号写到旧行的删除版本里。   

这种额外的记录所带来的结果就是对于大多数查询来说根本就不需要获得一个锁。

他们只是简单地以最快的速度来读取数据,确保只选择符合条件的行。

这个方案的缺点在于存储引擎必须为每一行存储更多的数据,做更多的检查工作,处理更多的善后操作。   

MVCC只工作在REPEATABLE READ和READ COMMITED隔离级别下。

READ UNCOMMITED不是MVCC兼容的,因为查询不能找到适合他们事务版本的行版本;

它们每次都只能读到最新的版本。

SERIABLABLE也不与MVCC兼容,因为读操作会锁定他们返回的每一行数据[1]

编辑本段说明

通过使用MVCC(Multi-Version Concurrency Control)算法自动提供并发控制。MVCC维持一个数据的多个版本使读写操作没有冲突。也就是说数据元素X上的每一个写操作产生X的一个新版本,GBase 8m为X的每一个读操作选择一个版本。由于消除了数据库中数据元素读和写操作的冲突,GBase 8m得到优化,具有更好的性能。特别是对于数据库读和写两种方法,他们不用等待其他同时进行的相同数据写和读的完成。在并发事务中,数据库写只等待正在对同一行数据进行更新的写,这是现有的行锁定方法的弱点。同时MVCC回收不需要的和长时间不用的内存,防止内存空间的浪费。MVCC优化了数据库并发系统,使系统在有大量并发用户时得到最高的性能,并且可以不用关闭服务器就直接进行热备份。

编辑本段比锁定的优势

使用MVCC多版本并发控制比锁定模型的主要优点是在MVCC里, 对检索(读)数据的锁要求与写数据的锁要求不冲突, 所以读不会阻塞写,而写也从不阻塞读。  在数据库里也有表和行级别的锁定机制, 用于给那些无法轻松接受 MVCC 行为的应用。 不过,恰当地使用 MVCC 总会提供比锁更好地性能。

编辑本段GBase8的特性

在 GBase 中的查询功能通过 MVCC 提供的一致性非锁读(在下文我们简称为一致性读),就是提供通过数据库在一个时间点上的快照来实现信息的查询。查询只是对那些在这个时间点之前提交的事务所做的变更,而并不关注在时间点之后的变更或未提交的事务。当然,若是该事务自身进行的变更,对于查询是可见的。  GBase 的默认级别是 READ COMMITTED ,在该隔离级别下事务中的查询语句,使用当前时间戳进行一致性读,每次查询的时间戳是不相同的。  但对 REPEATABLE READ 隔离级别,在同一个事务中的所有一致性读,使用的时间戳均是第一个查询的时间戳,这样读取的也就是由该事务第一次读建立起来的数据快照。用户只有通过提交当前事务,并发出一个新的查询才会得到新的数据快照。  一致性读是 GBase 在 READ COMMITTED 和 REPEATABLE READ 隔离级别下,处理 SELECT 语句中使用的默认模式。一致性读在它读的数据上不设置任何锁,因此在一致性读某个表的同时,其它用户均可以修改这个表。  注意在 DROP TABLE 和 ALTER TABLE 运作时,一致性读无效 。一致性读在 DROP TABLE 上无效是因为 GBase 不能使用已经 drop 的表,该表已经删除。一致性读在 ALTER TABLE 上无效是因为 GBase 会在事务内,重新创建一个新表并从旧表向新表插入记录。这样当用户再次执行一致性读时,在新表中将看不到任何行,因为在新表中的数据都在第一次一致性读的快照之外。
参考资料
  • 1

    《高性能MySQL》第二版

扩展阅读:
  • 1

    http://www.gbase.cn/onlineHelp/html/ManagerManual/ch04020202.html

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

화웨이는 내년에 혁신적인 MED 스토리지 제품을 출시할 예정입니다. 랙 용량은 10PB를 초과하고 전력 소비량은 2kW 미만입니다. 화웨이는 내년에 혁신적인 MED 스토리지 제품을 출시할 예정입니다. 랙 용량은 10PB를 초과하고 전력 소비량은 2kW 미만입니다. Mar 07, 2024 pm 10:43 PM

이 웹사이트는 3월 7일 화웨이의 데이터 스토리지 제품 라인 사장인 Zhou Yuefeng 박사가 최근 MWC2024 컨퍼런스에 참석하여 웜 데이터(WarmData)와 콜드 데이터(ColdData)용으로 설계된 차세대 OceanStorArctic 자전 스토리지 솔루션을 구체적으로 시연했다고 보도했습니다. Huawei의 데이터 스토리지 제품 라인 사장 Zhou Yuefeng은 일련의 혁신적인 솔루션을 출시했습니다. 이미지 출처: 이 사이트에 첨부된 Huawei의 공식 보도 자료는 다음과 같습니다. 이 솔루션의 가격은 자기 테이프보다 20% 저렴하며, 전력 소비는 하드 디스크보다 90% 낮습니다. 해외 기술 매체인 blockandfiles에 따르면, Huawei 대변인은 자기전기 저장 솔루션에 대한 정보도 공개했습니다. Huawei의 자기전자 디스크(MED)는 자기 저장 매체의 주요 혁신입니다. 1세대 ME

Vue3+TS+Vite 개발 기술: 데이터 암호화 및 저장 방법 Vue3+TS+Vite 개발 기술: 데이터 암호화 및 저장 방법 Sep 10, 2023 pm 04:51 PM

Vue3+TS+Vite 개발 팁: 데이터를 암호화하고 저장하는 방법 인터넷 기술의 급속한 발전으로 인해 데이터 보안 및 개인 정보 보호가 점점 더 중요해지고 있습니다. Vue3+TS+Vite 개발 환경에서 데이터를 암호화하고 저장하는 방법은 모든 개발자가 직면해야 하는 문제입니다. 이 기사에서는 개발자가 애플리케이션 보안 및 사용자 경험을 개선하는 데 도움이 되는 몇 가지 일반적인 데이터 암호화 및 저장 기술을 소개합니다. 1. 데이터 암호화 프런트엔드 데이터 암호화 프런트엔드 암호화는 데이터 보안을 보호하는 중요한 부분입니다. 일반적으로 사용되는

Windows 11에서 캐시를 지우는 방법: 사진이 포함된 자세한 튜토리얼 Windows 11에서 캐시를 지우는 방법: 사진이 포함된 자세한 튜토리얼 Apr 24, 2023 pm 09:37 PM

캐시란 무엇입니까? 캐시(ka·shay로 발음)는 자주 요청되는 데이터 및 지침을 저장하는 데 사용되는 특수 고속 하드웨어 또는 소프트웨어 구성 요소로, 웹 사이트, 애플리케이션, 서비스 및 기타 시스템 측면을 더 빠르게 로드하는 데 사용할 수 있습니다. . 캐싱을 사용하면 가장 자주 액세스하는 데이터를 쉽게 사용할 수 있습니다. 캐시 파일은 캐시 메모리와 동일하지 않습니다. 캐시 파일은 여러 프로그램에서 필요할 수 있는 PNG, 아이콘, 로고, 셰이더 등과 같이 자주 필요한 파일을 의미합니다. 이러한 파일은 일반적으로 숨겨져 있는 실제 드라이브 공간에 저장됩니다. 반면에 캐시 메모리는 주 메모리 및/또는 RAM보다 빠른 메모리 유형입니다. CPU에 더 가깝고 RAM에 비해 빠르기 때문에 데이터 액세스 시간을 크게 줄입니다.

우분투에서의 Git 설치 과정 우분투에서의 Git 설치 과정 Mar 20, 2024 pm 04:51 PM

Git은 빠르고 안정적이며 적응력이 뛰어난 분산 버전 제어 시스템입니다. 분산된 비선형 워크플로를 지원하도록 설계되어 모든 규모의 소프트웨어 개발 팀에 이상적입니다. 각 Git 작업 디렉터리는 모든 변경 사항에 대한 전체 기록을 보유하고 네트워크 액세스나 중앙 서버 없이도 버전을 추적할 수 있는 독립적인 저장소입니다. GitHub는 분산 개정 제어의 모든 기능을 제공하는 클라우드에 호스팅되는 Git 저장소입니다. GitHub는 클라우드에서 호스팅되는 Git 저장소입니다. CLI 도구인 Git과 달리 GitHub에는 웹 기반 그래픽 사용자 인터페이스가 있습니다. 이는 다른 개발자와 협력하고 스크립트 변경 사항을 추적하는 버전 제어에 사용됩니다.

PHP와 Swoole은 어떻게 효율적인 데이터 캐싱 및 저장을 달성합니까? PHP와 Swoole은 어떻게 효율적인 데이터 캐싱 및 저장을 달성합니까? Jul 23, 2023 pm 04:03 PM

PHP와 Swoole은 어떻게 효율적인 데이터 캐싱 및 저장을 달성합니까? 개요: 웹 애플리케이션 개발에서 데이터 캐싱 및 저장은 매우 중요한 부분입니다. PHP와 Swoole은 데이터를 캐시하고 저장하는 효율적인 방법을 제공합니다. 이 기사에서는 PHP와 Swoole을 사용하여 효율적인 데이터 캐싱 및 저장을 달성하는 방법을 소개하고 해당 코드 예제를 제공합니다. 1. swoole 소개: swoole은 PHP 언어용으로 개발된 고성능 비동기 네트워크 통신 엔진입니다.

민감한 데이터를 보호하기 위해 sessionStorage를 올바르게 사용하는 방법 민감한 데이터를 보호하기 위해 sessionStorage를 올바르게 사용하는 방법 Jan 13, 2024 am 11:54 AM

sessionStorage를 올바르게 사용하여 민감한 정보를 저장하려면 특정 코드 예제가 필요합니다. 웹 개발이든 모바일 애플리케이션 개발이든 사용자 로그인 자격 증명, ID 번호 등과 같은 민감한 정보를 저장하고 처리해야 하는 경우가 많습니다. 프런트엔드 개발에서는 sessionStorage를 사용하는 것이 일반적인 스토리지 솔루션입니다. 그러나 sessionStorage는 브라우저 기반 스토리지이기 때문에 저장된 민감한 정보가 악의적으로 접근 및 사용되지 않도록 몇 가지 보안 문제에 주의가 필요합니다.

한 글로 인공지능 테이블 이해하기: MindsDB로 시작하기 한 글로 인공지능 테이블 이해하기: MindsDB로 시작하기 Apr 12, 2023 pm 12:04 PM

이 기사는 WeChat 공개 계정 "정보 시대에 살기"에서 재인쇄되었습니다. 저자는 정보 시대에 살고 있습니다. 이 기사를 재인쇄하려면 Living in the Information Age 공개 계정에 문의하세요. 데이터베이스 작업에 익숙한 학생들에게는 멋진 SQL 문을 작성하고 데이터베이스에서 필요한 데이터를 찾는 방법을 찾는 것이 일상적인 작업입니다. 머신러닝에 익숙한 학생들에게는 데이터를 얻고, 데이터를 전처리하고, 모델을 구축하고, 훈련 세트와 테스트 세트를 결정하고, 훈련된 모델을 사용하여 미래에 대한 일련의 예측을 하는 것도 일상적인 작업입니다. 그렇다면 두 기술을 결합할 수 있을까요? 데이터는 데이터베이스에 저장되어 있으며 예측은 과거 데이터를 기반으로 해야 한다는 것을 알 수 있습니다. 데이터베이스에 존재하는 데이터를 통해 미래의 데이터를 쿼리하면,

PHP 배열을 사용한 데이터 캐싱 및 저장 방법 및 기술 PHP 배열을 사용한 데이터 캐싱 및 저장 방법 및 기술 Jul 16, 2023 pm 02:33 PM

PHP 배열을 사용하여 데이터 캐싱 및 저장을 구현하는 방법 및 기술 인터넷의 발전과 데이터 양의 급속한 증가로 인해 데이터 캐싱 및 저장은 개발 과정에서 고려해야 할 문제 중 하나가 되었습니다. 널리 사용되는 프로그래밍 언어인 PHP는 데이터 캐싱 및 저장을 구현하는 다양한 방법과 기술도 제공합니다. 그중에서도 데이터 캐싱과 저장을 위해 PHP 배열을 사용하는 것은 간단하고 효율적인 방법입니다. 1. 데이터 캐싱 데이터 캐싱의 목적은 데이터베이스나 기타 외부 데이터 소스에 대한 액세스 횟수를 줄여서

See all articles