찾다
데이터 베이스MySQL 튜토리얼MySQL Redo 및 Undo 로그란 무엇입니까?

    1. Redo 로그 소개

    Redo 로그는 페이지 변경 사항을 기록하는 물리적 로그입니다.

    1.1 Redo 로그의 역할

    • 데이터베이스 쓰기 효율성 향상

    • 데이터베이스가 데이터를 잃지 않도록 확인하고 데이터 복구를 수행

    1.2 Redo 로그의 형식과 유형

    소위 REDO 구성 방법은 필요한 REDO 콘텐츠를 디스크 파일에 기록하여 효율적인 REDO 쓰기, 읽기, 복구 및 정리를 용이하게 하는 방법입니다. 우리는 REDO를 위에서 아래로 논리적 REDO 계층, 물리적 REDO 계층, 파일 계층의 세 가지 계층으로 나눕니다.

    • 논리적 REDO 레이어

    이 레이어는 실제 REDO 콘텐츠이며, 순차적 데이터 흐름입니다. REDO는 전역적으로 고유한 증분 오프셋 sn을 사용하여 끝에 연결된 여러 REDO 레코드로 구성됩니다. 전역 log_sys에서 sn의 최대값이며 데이터가 기록될 때마다 REDO 콘텐츠 길이만큼 sn이 증가합니다.

    • 물리적 REDO 레이어

    디스크는 블록 장치이기도 합니다. 블록 OS_FILE_LOG_BLOCK_SIZE의 길이는 디스크 섹터 512B의 크기와 같습니다. 각 IO 읽기 및 쓰기는 블록입니다.

    • 파일 레이어

    마지막으로 REDO가 REDO 로그 파일에 기록되고 로그 파일이 루프에 기록됩니다

    MySQL Redo 및 Undo 로그란 무엇입니까?

    2. Redo 로그(MTR)를 작성하는 과정

    • 사용자 스레드의 작업은 먼저 로그 버퍼log buffer

    • log buffer

    • 로그 버퍼에 기록됩니다. Redo 논리 로그

    • 에 순차적으로 기록되고 나중에 디스크에 기록됩니다. 디스크에 저장소를 유지한 후

    사용자에게 저장소가 완료되었음을 알립니다

    3.

    체크포인트는 Redo 로그에서 더티 페이지를 표시하는 비트로, 다음 두 가지 기능을 가지고 있습니다.
    • Redo 로그를 유지하여 정리를 용이하게 합니다.
    • 다시 시작 작업 부하를 줄입니다

    MySQL Redo 및 Undo 로그란 무엇입니까?

    데이터베이스 복구 프로세스:
    • 체크포인트 정보 읽기 •체크포인트 위치부터 나머지 로그 읽기
    • 로그를 구문 분석하고 space_no 및 page_id에 따라 해시 테이블 구축
    • Redo 로그, Redo 로그 적용 재생은 멱등성을 보장합니다
    • binlog를 구문 분석하여 xid 목록 만들기
    • 롤백 세그먼트를 스캔하여 보류 중인 트랜잭션 목록 만들기
    • xid 목록에 없는 트랜잭션 롤백

    4. Undo log

    Undo 로그는 데이터의 증분 변화를 기록하는 논리적 로그이며, 그 기능은 트랜잭션의 원자성을 보장하고 트랜잭션 동시성 제어를 수행하는 것입니다. 다시 작성됨: 실행 취소 로그는 논리적 로그 역할을 하는 데이터의 증분 변경 사항을 기록하여 트랜잭션의 원자성을 보장하고 동시성을 제어하는 ​​역할을 합니다. 트랜잭션을 롤백하고, 다중 버전 제어(MVCC)를 구현하고, 읽기-쓰기 충돌과 일관된 읽기를 해결하는 데 사용할 수 있습니다.

    5. MVCC

    MVCC의 의미:
    • 읽기와 쓰기는 서로를 막지 않습니다.
    • 교착 상태의 가능성을 줄입니다.
    MVCC에서 UndoLog의 역할:

      각 트랜잭션에는 단일 증분 트랜잭션 ID가 있습니다.
    • 데이터 페이지의 행 레코드에는 DB_ROW_ID, DB_TRX_ID, DB_ROLL_PTR이 포함됩니다.
    • DB_ROLL_PTR 데이터 행의 모든 ​​스냅샷 레코드는 연결된 목록 구조를 통해 연결됩니다.

    위 내용은 MySQL Redo 및 Undo 로그란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명
    이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
    MySQL : 초보자가 마스터하는 필수 기술MySQL : 초보자가 마스터하는 필수 기술Apr 18, 2025 am 12:24 AM

    MySQL은 초보자가 데이터베이스 기술을 배우는 데 적합합니다. 1. MySQL 서버 및 클라이언트 도구를 설치하십시오. 2. SELECT와 같은 기본 SQL 쿼리를 이해하십시오. 3. 마스터 데이터 작업 : 데이터를 만들고, 삽입, 업데이트 및 삭제합니다. 4. 고급 기술 배우기 : 하위 쿼리 및 창 함수. 5. 디버깅 및 최적화 : 구문 확인, 인덱스 사용, 선택*을 피하고 제한을 사용하십시오.

    MySQL : 구조화 된 데이터 및 관계형 데이터베이스MySQL : 구조화 된 데이터 및 관계형 데이터베이스Apr 18, 2025 am 12:22 AM

    MySQL은 테이블 구조 및 SQL 쿼리를 통해 구조화 된 데이터를 효율적으로 관리하고 외래 키를 통해 테이블 ​​간 관계를 구현합니다. 1. 테이블을 만들 때 데이터 형식을 정의하고 입력하십시오. 2. 외래 키를 사용하여 테이블 간의 관계를 설정하십시오. 3. 인덱싱 및 쿼리 최적화를 통해 성능을 향상시킵니다. 4. 데이터 보안 및 성능 최적화를 보장하기 위해 데이터베이스를 정기적으로 백업 및 모니터링합니다.

    MySQL : 주요 기능 및 기능이 설명되었습니다MySQL : 주요 기능 및 기능이 설명되었습니다Apr 18, 2025 am 12:17 AM

    MySQL은 웹 개발에 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 주요 기능에는 다음이 포함됩니다. 1. 다른 시나리오에 적합한 InnoDB 및 MyISAM과 같은 여러 스토리지 엔진을 지원합니다. 2.로드 밸런싱 및 데이터 백업을 용이하게하기 위해 마스터 슬레이브 복제 기능을 제공합니다. 3. 쿼리 최적화 및 색인 사용을 통해 쿼리 효율성을 향상시킵니다.

    SQL의 목적 : MySQL 데이터베이스와 상호 작용합니다SQL의 목적 : MySQL 데이터베이스와 상호 작용합니다Apr 18, 2025 am 12:12 AM

    SQL은 MySQL 데이터베이스와 상호 작용하여 데이터 첨가, 삭제, 수정, 검사 및 데이터베이스 설계를 실현하는 데 사용됩니다. 1) SQL은 Select, Insert, Update, Delete 문을 통해 데이터 작업을 수행합니다. 2) 데이터베이스 설계 및 관리에 대한 생성, 변경, 삭제 문을 사용하십시오. 3) 복잡한 쿼리 및 데이터 분석은 SQL을 통해 구현되어 비즈니스 의사 결정 효율성을 향상시킵니다.

    초보자를위한 MySQL : 데이터베이스 관리를 시작합니다초보자를위한 MySQL : 데이터베이스 관리를 시작합니다Apr 18, 2025 am 12:10 AM

    MySQL의 기본 작업에는 데이터베이스, 테이블 작성 및 SQL을 사용하여 데이터에서 CRUD 작업을 수행하는 것이 포함됩니다. 1. 데이터베이스 생성 : createAbasemy_first_db; 2. 테이블 만들기 : CreateTableBooks (idintauto_incrementprimarykey, titlevarchar (100) notnull, authorvarchar (100) notnull, published_yearint); 3. 데이터 삽입 : InsertIntobooks (Title, Author, Published_year) VA

    MySQL의 역할 : 웹 응용 프로그램의 데이터베이스MySQL의 역할 : 웹 응용 프로그램의 데이터베이스Apr 17, 2025 am 12:23 AM

    웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

    MySQL : 첫 번째 데이터베이스 구축MySQL : 첫 번째 데이터베이스 구축Apr 17, 2025 am 12:22 AM

    MySQL 데이터베이스를 구축하는 단계에는 다음이 포함됩니다. 1. 데이터베이스 및 테이블 작성, 2. 데이터 삽입 및 3. 쿼리를 수행하십시오. 먼저 CreateAbase 및 CreateTable 문을 사용하여 데이터베이스 및 테이블을 작성한 다음 InsertInto 문을 사용하여 데이터를 삽입 한 다음 최종적으로 SELECT 문을 사용하여 데이터를 쿼리하십시오.

    MySQL : 데이터 저장에 대한 초보자 친화적 인 접근 방식MySQL : 데이터 저장에 대한 초보자 친화적 인 접근 방식Apr 17, 2025 am 12:21 AM

    MySQL은 사용하기 쉽고 강력하기 때문에 초보자에게 적합합니다. 1.MySQL은 관계형 데이터베이스이며 CRUD 작업에 SQL을 사용합니다. 2. 설치가 간단하고 루트 사용자 비밀번호를 구성해야합니다. 3. 삽입, 업데이트, 삭제 및 선택하여 데이터 작업을 수행하십시오. 4. Orderby, Where and Join은 복잡한 쿼리에 사용될 수 있습니다. 5. 디버깅은 구문을 확인하고 쿼리를 분석하기 위해 설명을 사용해야합니다. 6. 최적화 제안에는 인덱스 사용, 올바른 데이터 유형 선택 및 우수한 프로그래밍 습관이 포함됩니다.

    See all articles

    핫 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 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    뜨거운 도구

    PhpStorm 맥 버전

    PhpStorm 맥 버전

    최신(2018.2.1) 전문 PHP 통합 개발 도구

    SublimeText3 Linux 새 버전

    SublimeText3 Linux 새 버전

    SublimeText3 Linux 최신 버전

    VSCode Windows 64비트 다운로드

    VSCode Windows 64비트 다운로드

    Microsoft에서 출시한 강력한 무료 IDE 편집기

    ZendStudio 13.5.1 맥

    ZendStudio 13.5.1 맥

    강력한 PHP 통합 개발 환경

    메모장++7.3.1

    메모장++7.3.1

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