데이터 베이스 MySQL 튜토리얼 MySQL主从复制不一致的解决办法

MySQL主从复制不一致的解决办法

Jun 07, 2016 pm 05:52 PM
마스터-슬레이브 복제

稍微有些规模的网站,基本上都会配置mysql主从复制,一方面用mysql的主从做数据库的读写分离,另一方面mysql本身的单机备份不是很强,一般采用主从架构,在从上进行数据备份。

在MySQL主从复制程中或多少出现一些主从不同步的情况,本文将对数据主从不同步的情况进行简单的总结,请注意本文主要从数据库层面上探讨数据库的主从不一致的情况。
1.网络的延迟

由于mysql主从复制是基于binlog的一种异步复制,通过网络传送binlog文件,理所当然网络延迟是主从不同步的绝大多数的原因,特别是跨机房的数据同步出现这种几率非常的大,所以做读写分离,注意从业务层进行前期设计。

2.主从两台机器的负载不一致

由于mysql主从复制是主数据库上面启动1个io线程,而从上面启动1个sql线程和1个io线程,当中任何一台机器的负载很高,忙不过来,导致其中的任何一个线程出现资源不足,都将出现主从不一致的情况。

3.max_allowed_packet设置不一致

主数据库上面设置的max_allowed_packet比从数据库大,当一个大的sql语句,能在主数据库上面执行完毕,从数据库上面设置过小,无法执行,导致的主从不一致。

4.key自增键开始的键值跟自增步长设置不一致引起的主从不一致。

5.mysql异常宕机情况下,如果未设置sync_binlog=1或者innodb_flush_log_at_trx_commit=1很有可能出现binlog或者relaylog文件出现损坏,导致主从不一致。

6.mysql本身的bug引起的主从不同步。

7.版本不一致,特别是高版本是主,低版本为从的情况下,主数据库上面支持的功能,从数据库上面不支持该功能。

以上就是常见的一些主从不同步的情况。或许还有其他的一些不同步的情况,请说出你所遇到的主从不一致的情况。

基于以上情况,先保证max_allowed_packet、自增键开始点和增长点设置一致,再者牺牲部分性能在主上面开启sync_binlog,对于采用innodb的库,推荐配置下面的内容

 代码如下 复制代码

1、innodb_flush_logs_at_trx_commit = 1
2、innodb-support_xa = 1 # Mysql 5.0 以上
3、innodb_safe_binlog      # Mysql 4.0

同时在从数据库上面推荐加入下面两个参数

1、skip_slave_start
2、read_only

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

PHP에서 MySQL 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법 PHP에서 MySQL 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법 May 17, 2023 am 08:18 AM

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

고가용성 MySQL 클러스터 구축: 마스터-슬레이브 복제 및 로드 밸런싱을 위한 모범 사례 가이드 고가용성 MySQL 클러스터 구축: 마스터-슬레이브 복제 및 로드 밸런싱을 위한 모범 사례 가이드 Sep 09, 2023 am 10:57 AM

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

MySQL의 데이터 마스터-슬레이브 복제 기술 MySQL의 데이터 마스터-슬레이브 복제 기술 Jun 14, 2023 pm 02:10 PM

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

Redis의 마스터-슬레이브 복제 기능에 대한 자세한 설명 Redis의 마스터-슬레이브 복제 기능에 대한 자세한 설명 May 11, 2023 am 10:00 AM

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

MySQL 데이터베이스의 마스터-슬레이브 복제를 구성하는 방법은 무엇입니까? MySQL 데이터베이스의 마스터-슬레이브 복제를 구성하는 방법은 무엇입니까? Jul 13, 2023 pm 10:05 PM

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

MySQL의 마스터-슬레이브 복제 및 고가용성 아키텍처 MySQL의 마스터-슬레이브 복제 및 고가용성 아키텍처 Sep 09, 2023 pm 12:03 PM

MySQL의 마스터-슬레이브 복제 및 고가용성 아키텍처 인터넷 애플리케이션과 데이터 볼륨이 계속 증가함에 따라 데이터베이스의 고가용성과 확장성이 점점 더 중요해지고 있습니다. 널리 사용되는 오픈 소스 관계형 데이터베이스인 MySQL은 마스터-슬레이브 복제 및 고가용성 아키텍처 솔루션을 제공합니다. 마스터-슬레이브 복제는 MySQL 데이터베이스 인스턴스를 마스터 데이터베이스로 사용하고 해당 데이터를 하나 이상의 슬레이브 데이터베이스(슬레이브)에 복제하는 프로세스를 나타냅니다. 이 복제 방법은 데이터의 중복 백업과 읽기 및 쓰기의 분리를 달성할 수 있습니다.

클러스터 모드의 로드 밸런싱 및 재해 복구: MySQL 마스터-슬레이브 복제에 대한 심층 분석 및 실습 클러스터 모드의 로드 밸런싱 및 재해 복구: MySQL 마스터-슬레이브 복제에 대한 심층 분석 및 실습 Sep 11, 2023 pm 05:51 PM

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

PHP에서 Memcached 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법 PHP에서 Memcached 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법 May 15, 2023 pm 06:40 PM

Memcached는 웹 애플리케이션 속도를 높이는 데 사용할 수 있고 특히 대규모 데이터 캐싱에서 탁월한 성능을 발휘하는 오픈 소스 고성능 분산 메모리 객체 캐싱 시스템입니다. 이 시스템에서 마스터-슬레이브 복제는 데이터 신뢰성과 고가용성을 보장하는 데 사용할 수 있는 매우 중요한 기능입니다. 이 기사에서는 PHP를 사용하여 Memcached 데이터베이스의 마스터-슬레이브 복제를 구현하는 방법을 소개합니다. 마스터-슬레이브 모드 소개 마스터-슬레이브 모드는 Memcached 서버의 분산 구조입니다. 이는 최소한 두 개의 서버로 구성됩니다.

See all articles