수요원인
동시성이 높은 비즈니스 시나리오에서 데이터베이스는 대부분의 경우 동시 사용자 액세스에 대한 가장 취약한 링크입니다. 따라서 요청이 MySQL 등의 데이터베이스에 직접 접근하는 대신 Redis에 먼저 접근할 수 있도록 Redis를 이용하여 버퍼링 작업을 수행해야 합니다.
이 비즈니스 시나리오는 주로 Redis 캐시에서 데이터를 읽는 문제를 해결합니다. 비즈니스 작업은 일반적으로 아래 그림의 프로세스에 따라 수행됩니다.
일반적으로 캐시 단계를 읽는 데에는 문제가 없지만, 일단 데이터 업데이트(데이터베이스 및 캐시 업데이트)가 포함되면 캐시(Redis)와 데이터베이스(MySQL) 간의 데이터 일관성 문제가 발생하기 쉽습니다.
MySQL 데이터베이스를 먼저 작성한 다음 Redis 캐시를 삭제하거나, 캐시를 먼저 삭제하고 데이터베이스에 쓰는 경우 데이터 불일치가 발생할 수 있습니다. 예를 들어보세요:
1. Redis 캐시가 삭제되고 MySQL 데이터베이스에 쓸 시간이 되기 전에 다른 스레드가 읽기 시작하여 캐시가 비어 있음을 발견하면 이때 데이터베이스에서 데이터를 읽어 캐시에 씁니다. , 캐시에 더티 데이터가 포함되어 있습니다.
2. 라이브러리가 먼저 작성되고 캐시가 삭제되기 전에 라이브러리를 작성하는 스레드가 충돌하고 캐시가 삭제되지 않으면 데이터 불일치도 발생합니다.
쓰기와 읽기가 동시적이고 순서를 보장할 수 없기 때문에 캐시와 데이터베이스 간에 데이터 불일치가 발생합니다.
여래가 해결해 주나요? 다음은 비즈니스 및 기술 비용을 기준으로 선택한 두 가지 솔루션입니다. 먼저 쉬운 솔루션과 어려운 솔루션이 있습니다.
캐싱 및 데이터베이스 일관성 솔루션
1. 첫 번째 옵션: 지연된 이중 삭제 전략 채택
라이브러리 쓰기 전후에 redis.del(키) 작업을 수행하고 합리적인 시간 초과를 설정합니다.
의사 코드는 다음과 같습니다
공개 무효 쓰기(문자열 키, 객체 데이터){
redis.delKey(키);
db.updateData(데이터);
Thread.sleep(500);
redis.delKey(키);
}
2. 구체적인 단계는 다음과 같습니다:
1) 캐시를 먼저 삭제하세요
2) 데이터베이스를 다시 작성합니다
3) 500밀리초 동안 잠을 자세요
4) 캐시를 다시 삭제하세요
그렇다면 이 500밀리초는 어떻게 결정되며, 얼마나 오랫동안 절전 모드로 유지되어야 할까요?
시간이 많이 걸리는 프로젝트의 데이터 읽기 비즈니스 로직을 평가해야 합니다. 이는 읽기 요청이 종료되고 쓰기 요청이 읽기 요청으로 인해 캐시된 더티 데이터를 삭제할 수 있도록 하는 것입니다.
물론 이 전략에서는 Redis와 데이터베이스 마스터-슬레이브 간의 시간 소모적인 동기화도 고려해야 합니다. 데이터 쓰기를 위한 최종 대기 시간: 데이터 비즈니스 로직을 읽는 데 걸리는 시간에 수백 밀리초를 추가합니다. 예: 1초 동안 잠을 자세요.
3.캐시 만료 시간 설정
이론적으로 캐시 만료 시간을 설정하는 것은 최종 일관성을 보장하는 솔루션입니다. 모든 쓰기 작업에는 데이터베이스가 적용됩니다. 캐시 만료 시간에 도달하는 한 후속 읽기 요청은 자연스럽게 데이터베이스에서 새 값을 읽고 캐시를 채웁니다.
4. 이 플랜의 단점
이중 삭제 전략 + 캐시 시간 초과 설정을 결합하면 최악의 시나리오는 시간 초과 기간 내에 데이터가 일관되지 않고 요청 쓰기 시간도 늘어나는 것입니다.
2. 두 번째 해결 방법: 비동기 업데이트 캐시(binlog 구독을 기반으로 한 동기화 메커니즘)
1. 전반적인 기술 아이디어:
MySQL binlog 증분 구독 소비 + 메시지 큐 + redis에 대한 증분 데이터 업데이트
1) Redis 읽기: 핫 데이터는 기본적으로 Redis
에 있습니다. 2) MySQL 작성: 추가, 삭제, 수정이 모두 MySQL에서 이루어집니다
3) Redis 데이터 업데이트: Redis
로 업데이트하기 위한 MySQ 데이터 작업 binlog 2.Redis 업데이트
1) 데이터 작업은 주로 두 가지 블록으로 나뉩니다.
하나는 전체 볼륨입니다(모든 데이터를 Redis에 동시에 쓰기)
하나는 증분(실시간 업데이트)
여기서 말하는 increment는 mysql의 변경 데이터를 업데이트, 삽입, 삭제하는 것을 의미하는 increment이다.
2) binlog를 읽은 후 이를 분석하고 메시지 큐를 사용하여 각 스테이션의 Redis 캐시 데이터를 푸시하고 업데이트합니다.
이러한 방식으로 MySQL에서 새로운 쓰기, 업데이트, 삭제 및 기타 작업이 발생하면 binlog 관련 메시지가 Redis로 푸시될 수 있으며 Redis는 binlog의 레코드를 기반으로 Redis를 업데이트합니다.
실제로 이 메커니즘은 MySQL의 마스터-슬레이브 백업 메커니즘과 매우 유사합니다. 왜냐하면 MySQL의 마스터-슬레이브 백업도 binlog를 통해 데이터 일관성을 달성하기 때문입니다.
여기에서는 canal(Alibaba의 오픈 소스 프레임워크)을 조합하여 사용할 수 있으며 이를 통해 MySQL의 binlog를 구독할 수 있습니다. Canal은 mysql의 슬레이브 데이터베이스의 백업 요청을 모방하므로 Redis의 데이터 업데이트가 동일한 효과를 얻습니다.
물론 여기에서 메시지 푸시 도구로 다른 제3자(kafka, RabbitMQ 등)를 사용하여 Redis에 업데이트를 푸시할 수도 있습니다.
위 내용은 Redis 캐시 및 MySQL 데이터 일관성 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

innodbbufferpool은 데이터와 인덱싱 페이지를 캐싱하여 디스크 I/O를 줄여 데이터베이스 성능을 향상시킵니다. 작업 원칙에는 다음이 포함됩니다. 1. 데이터 읽기 : BufferPool의 데이터 읽기; 2. 데이터 작성 : 데이터 수정 후 BufferPool에 쓰고 정기적으로 디스크로 새로 고치십시오. 3. 캐시 관리 : LRU 알고리즘을 사용하여 캐시 페이지를 관리합니다. 4. 읽기 메커니즘 : 인접한 데이터 페이지를 미리로드합니다. Bufferpool을 크기를 조정하고 여러 인스턴스를 사용하여 데이터베이스 성능을 최적화 할 수 있습니다.

다른 프로그래밍 언어와 비교할 때 MySQL은 주로 데이터를 저장하고 관리하는 데 사용되는 반면 Python, Java 및 C와 같은 다른 언어는 논리적 처리 및 응용 프로그램 개발에 사용됩니다. MySQL은 데이터 관리 요구에 적합한 고성능, 확장 성 및 크로스 플랫폼 지원으로 유명하며 다른 언어는 데이터 분석, 엔터프라이즈 애플리케이션 및 시스템 프로그래밍과 같은 해당 분야에서 이점이 있습니다.

MySQL은 데이터 저장, 관리 및 분석에 적합한 강력한 오픈 소스 데이터베이스 관리 시스템이기 때문에 학습 할 가치가 있습니다. 1) MySQL은 SQL을 사용하여 데이터를 작동하고 구조화 된 데이터 관리에 적합한 관계형 데이터베이스입니다. 2) SQL 언어는 MySQL과 상호 작용하는 열쇠이며 CRUD 작업을 지원합니다. 3) MySQL의 작동 원리에는 클라이언트/서버 아키텍처, 스토리지 엔진 및 쿼리 최적화가 포함됩니다. 4) 기본 사용에는 데이터베이스 및 테이블 작성이 포함되며 고급 사용량은 Join을 사용하여 테이블을 결합하는 것과 관련이 있습니다. 5) 일반적인 오류에는 구문 오류 및 권한 문제가 포함되며 디버깅 기술에는 구문 확인 및 설명 명령 사용이 포함됩니다. 6) 성능 최적화에는 인덱스 사용, SQL 문의 최적화 및 데이터베이스의 정기 유지 보수가 포함됩니다.

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

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

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

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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