마스터-슬레이브 복제 문제로 인한 아키텍처 최적화에 대한 생각
문제가 있습니다
마스터-슬레이브 복제 아키텍처는 1032 오류, 1062 오류 등 복제 정체 문제가 많습니다. 그 중 마스터 데이터베이스 성공 후 1032 오류가 발생합니다. 슬레이브 데이터베이스의 업데이트 또는 업데이트를 실행하는 중, 슬레이브 라이브러리에서 이 레코드를 찾을 수 없는 것으로 나타났습니다. 1062 오류는 메인 라이브러리 이후 슬레이브 라이브러리를 실행했을 때 발생한 기본 키 충돌로 인해 발생했습니다. 삽입이 완료되어 삽입에 성공하지 못했습니다. 이러한 문제는 오류 및 이전 복사본 데이터 확인을 건너뛰면 해결될 수 있지만 이러한 문제의 직접적인 원인은 마스터-슬레이브 데이터베이스 데이터의 불일치입니다. 이러한 불일치는 논리적 복제 자체에서 발생할 수 있는 데이터 불일치 외에도 비즈니스 측이나 개발자가 규정을 위반하여 대기 데이터베이스에 대한 추가, 삭제, 수정 작업을 직접 수행하는 경우에도 발생합니다.
마스터-슬레이브 복제 아키텍처에서 마스터-슬레이브 라이브러리는 VIP 바인딩을 구현하여 해당 라이브러리를 마스터 라이브러리로 지정하여 읽기 및 쓰기 기능을 제공하며, 문제 발생 시 슬레이브 라이브러리가 백업 역할을 합니다. 마스터 라이브러리에서 VIP는 슬레이브 라이브러리로 전환됩니다. 슬레이브 라이브러리는 읽기 및 쓰기를 제공합니다. 그렇지 않으면 슬레이브 라이브러리는 백업일 뿐입니다. 일반적인 상황에서는 개발자가 고정 IP를 통해 슬레이브 데이터베이스에 직접 로그인하는 것을 허용하지 않지만, 실제 작업에서는 이를 피하기 어려운 경우가 많습니다. 그렇다면 기술적 관점에서 개발자가 슬레이브 데이터베이스에서 작업하는 것을 방지하는 방법은 무엇일까요? 고가용성 아키텍처의 정상적인 작동 및 장애 조치에 영향을 주지 않고 이를 방지하려면 어떻게 해야 합니까?
2. 아키텍처 구성 최적화
(1) 직접적인 해결 방법
위의 문제를 해결하는 직접적인 방법은 고려 아키텍처 구성이 최적화되었습니다. 즉, 슬레이브 라이브러리의 읽기-쓰기 상태가 읽기 전용 상태로 구성됩니다.
MySQL 공식 홈페이지에는 읽기 전용에 대해 다음과 같은 설명이 있습니다.
1.Whenthe read_only system variable is enabled, the server permits no client updatesexcept from users who have the SUPER privilege. 只读情况下,super权限可读写。 2.Updates performed by slave threads, if theserver is a replication slave. In replication setups, it can be useful toenable read_only on slave servers to ensure that slaves accept updates only from themaster server and not from clients. 不影响主从复制线程的读写。
읽기 전용을 켠 후 슈퍼 권한 계정 및 복제 스레드 등을 제외하고 비즈니스 측 개발자 및 기타 백업 서버에 로그인하더라도 인력은 영향을 받지 않습니다. 데이터베이스는 대기 데이터베이스 데이터도 작동할 수 없습니다.
MySQL [db1]> show global variables like'read_only%'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | read_only | ON | +---------------+-------+ 1 row in set (0.00 sec) MySQL [test]> insert child values('1','12'); ERROR 1290 (HY000): The MySQL server is running withthe --read-only option so it cannot execute thisstatement
(2) 읽기 전용으로 설정한 후 완벽한 Failover를 수행하려면 어떻게 해야 하나요?
슬레이브 라이브러리에서 읽기 전용으로 불법 운영을 피할 수 있지만, 문제는 메인 라이브러리에 문제가 생기면 VIP가 슬레이브 라이브러리로 전환해야 하는데, 이때 슬레이브 라이브러리에서 읽기 전용을 수행하면 데이터베이스가 외부 서비스를 사용할 수 없게 되므로 전환 시 슬레이브 라이브러리의 읽기 전용 기능을 취소하고 메인 라이브러리의 읽기 전용 기능을 설정해야 합니다. .
Keepalived + MySQL 이중 마스터(마스터-슬레이브) 아키텍처를 예로 들면, 정상 작동 중에 VIP는 Master1에 있고 Master1은 읽기-쓰기 상태이고 Master2는 읽기 전용 상태입니다. Master1에 문제가 발생하면 VIP는 자동으로 Master2로 전환됩니다. 전환하기 전에 두 단계를 완료해야 합니다. 1. Master1을 읽기 전용으로 설정합니다. 2. Master2의 읽기 전용을 취소합니다.
3. 자동화된 구현 아이디어
마스터-슬레이브 아키텍처의 경우 장애 조치를 수동으로 수행해야 하므로 위의 두 단계도 수동으로 수행할 수 있지만 Keepalived는 수행할 수 없습니다. +MySQL 듀얼 마스터(마스터-슬레이브 아키텍처에서는 자동 오류 모니터링 및 자동 VIP 전환이 구현되었습니다. 자동화를 달성하려면 위의 두 단계도 스크립트에 포함되어야 합니다.
주로 자동 모니터링 및 전환 스크립트에는 데이터베이스에 대한 읽기 전용을 켜고 끄는 기능을 포함해야 합니다. 주로 "set global read_only=ON" 및 "set globalread_only=OFF" 명령문을 작성합니다. 동시에, 상태를 설정하기 전에 먼저 기존 상태를 확인하십시오. 쉘은 읽기 및 쓰기 상태를 확인하기 위해 "'read_only';"라는 명령문을 호출합니다. 읽기 전용 매개변수를 필수 상태로 설정하십시오. 이러한 상태 설정의 트리거 사용자 정의는 오류가 감지되고 전환이 수행되기 전입니다.
위 아이디어는 이제 자동으로 변환되어 개인 테스트에 성공하여 아이디어가 맞다는 것을 알 수 있습니다.
위 내용은 마스터-슬레이브 복제 문제로 인한 아키텍처 최적화 사고 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 주목해주세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제









인터넷의 급속한 발전으로 인해 웹 애플리케이션은 점점 더 데이터베이스 작업을 통합하고 있습니다. MySQL은 널리 사용되는 세계적으로 유명한 관계형 데이터베이스 시스템입니다. 동시성 웹 애플리케이션에서 MySQL 마스터-슬레이브 복제는 데이터베이스 성능과 가용성을 향상시키는 중요한 방법입니다. 이 기사에서는 PHP를 사용하여 MySQL 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법을 소개합니다. 1. MySQL 마스터-슬레이브 복제란 무엇입니까? MySQL 마스터-슬레이브 복제는 한 MySQL 데이터베이스 서버에서 다른 서버로 데이터를 복사하는 것을 의미합니다.

고가용성 MySQL 클러스터 구축: 마스터-슬레이브 복제 및 로드 밸런싱을 위한 모범 사례 가이드 최근 몇 년간 인터넷의 급속한 발전과 함께 데이터베이스는 대부분의 웹 애플리케이션에 대한 핵심 데이터 저장 및 처리 엔진 중 하나가 되었습니다. 이 시나리오에서는 고가용성과 로드 밸런싱이 데이터베이스 아키텍처 설계에서 중요한 고려 사항이 되었습니다. 가장 인기 있는 오픈 소스 관계형 데이터베이스 중 하나인 MySQL의 클러스터 배포 솔루션은 많은 주목을 받았습니다. 이 기사에서는 MySQL 마스터-슬레이브 복제 및 로드 밸런싱을 통해 고가용성 데이터베이스 클러스터를 구현하는 방법을 소개합니다.

MySQL 데이터베이스는 다양한 데이터 복제 기술을 지원하는 매우 널리 사용되는 관계형 데이터베이스 관리 시스템이며, 그 중 가장 일반적으로 사용되는 것은 마스터-슬레이브 복제 기술입니다. 이 기사에서는 MySQL의 데이터 마스터-슬레이브 복제 기술에 대한 원리, 구현 방법, 일반적인 문제 및 대책을 소개합니다. 1. 마스터-슬레이브 복제 기술의 원리 MySQL의 마스터-슬레이브 복제 기술은 MySQL 데이터베이스의 데이터를 다른 서버로 복사하여 데이터 백업, 로드 밸런싱, 읽기-쓰기 분리 및 기타 기능을 달성할 수 있습니다. 기본 원칙은 기본 데이터베이스를 변환하는 것입니다.

Redis는 캐싱, 큐잉 및 실시간 데이터 처리와 같은 시나리오에서 일반적으로 사용되는 오픈 소스 메모리 기반 키-값 스토리지 시스템입니다. 대규모 애플리케이션에서는 Redis의 가용성과 성능을 향상시키기 위해 마스터-슬레이브 복제가 일반적으로 사용되는 메커니즘인 분산 아키텍처를 채택해야 하는 경우가 많습니다. 이 기사에서는 정의, 원칙, 구성 및 애플리케이션 시나리오를 포함하여 Redis의 마스터-슬레이브 복제 기능을 소개합니다. 1. Redis 마스터-슬레이브 복제의 정의는 하나의 Redis 노드(즉, 마스터 노드)의 데이터를 다른 노드(즉, 슬레이브 노드)에 자동으로 동기화하는 것을 의미합니다.

MySQL 데이터베이스의 마스터-슬레이브 복제를 구성하는 방법은 무엇입니까? MySQL 데이터베이스의 마스터-슬레이브 복제는 일반적인 데이터 백업 및 고가용성 솔루션입니다. 마스터-슬레이브 복제를 구성하면 한 MySQL 서버(마스터 서버)에서 다른 MySQL 서버(슬레이브 서버)로 데이터를 동기화할 수 있으므로 데이터베이스 가용성과 성능이 향상됩니다. 다음은 MySQL 데이터베이스에서 마스터-슬레이브 복제를 구성하는 방법을 설명하고 해당 코드 예제를 제공합니다. MySQL 서버가 설치되어 시작되었는지 확인하십시오. 먼저 시스템에 MySQL이 설치되어 있는지 확인하십시오.

인터넷과 모바일 인터넷의 급속한 발전으로 인해 웹 애플리케이션은 우리 일상 생활에서 점점 더 중요한 역할을 하고 있습니다. 이러한 웹 애플리케이션에서는 PHP와 데이터베이스가 널리 사용됩니다. 그러나 사용자 수가 증가함에 따라 웹 애플리케이션의 성능 문제는 점점 더 두드러지고 있습니다. 따라서 PHP와 데이터베이스 스키마 최적화는 웹 애플리케이션에서 매우 중요합니다. 캐싱 사용 MySQL 캐싱은 요청 전반에 걸쳐 데이터를 저장하는 기술입니다. memcached를 사용하여 PHP에 액세스할 수 있습니다.

데이터 이중화 및 확장 실현: 클러스터 환경에서 MySQL 마스터-슬레이브 복제 기술 적용 사례 소개: 인터넷의 발달, 데이터 양 및 사용자 수의 증가로 인해 기존의 독립형 데이터베이스는 더 이상 요구 사항을 충족할 수 없습니다. 높은 동시성 및 고가용성이 필요합니다. 이러한 맥락에서 분산 데이터베이스는 널리 사용되는 솔루션 중 하나가 되었습니다. 가장 일반적으로 사용되는 관계형 데이터베이스 중 하나인 MySQL의 마스터-슬레이브 복제 기술은 분산 데이터베이스에서도 광범위한 주목을 받았습니다. 이 기사에서는 클러스터 환경에서 MySQL 마스터-슬레이브 복제 기술을 소개합니다.

클러스터 모드의 로드 밸런싱 및 재해 복구: MySQL 마스터-슬레이브 복제에 대한 심층 분석 및 실행 인터넷 산업의 급속한 발전으로 인해 데이터 저장 및 처리에 대한 수요가 점점 더 높아지고 있습니다. 높은 동시 액세스와 대용량 데이터 저장에 대응하여 클러스터 모드가 일반적인 솔루션이 되었습니다. 로드 밸런싱 및 재해 복구는 클러스터 시스템의 중요한 구성 요소이며 MySQL 마스터-슬레이브 복제는 널리 사용되는 방법입니다. 이 기사에서는 MySQL 마스터-슬레이브 복제 원리에 초점을 맞춰 클러스터 모드의 로드 밸런싱 및 재해 복구에 대해 자세히 설명합니다.
