데이터 베이스 MySQL 튜토리얼 MySQL主从,半同步,主主复制

MySQL主从,半同步,主主复制

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

我们知道,MySQL数据库的二进制日志记录着每一个明确或者潜在可能导致数据库发生改变的sql语句,因此我们可以基于二进制日志来实

MySQL Replication

我们知道,MySQL数据库的二进制日志记录着每一个明确或者潜在可能导致数据库发生改变的sql语句,因此我们可以基于二进制日志来实现mysql的主从一致。而我们在此提到的mysql的复制的简单过程就是:
首先mysql的主服务器(Master)上有一个叫dump的线程,负责将二进制日志读取进来,发送给slave.
而后mysql的从服务器(Slave)上有个I/O线程 ,负责接收Master传送过来的二进制日志数据,并且将此写入到本地的中继日志中,此时会有一个SQL线程,每次中继日志读取一句sql语句, 并在从Slave上应用,以实现主从服务器的一致。
 
首先需要提供2台mysql版本一致的mysql服务器,,在此选用的mysql-5.5.20,平台为RedHat5.4
 
一、安装mysql-5.5.20
 
# groupadd -r mysql 
# useradd -g mysql -r -s /sbin/nologin –M mysql         
                                           //新建用户以安全方式运行进程
# chown -R mysql:mysql /mydata/data
 
# tar xf mysql-5.5.20-linux2.6-i686.tar.gz -C /usr/local 
                                          //将下载好的mysql软件解压安装
# cd /usr/local/
# ln -sv mysql-5.5.20-linux2.6-i686  mysql
# cd mysql
 
# chown -R mysql:mysql  .
# scripts/mysql_install_db --user=mysql --datadir=/mydata/mysql
//初始化mysql,此处使用的/mydata/mysql存放mysql的数据,建议将/mydata挂载至一个逻辑卷,方便数据备份
# chown -R root  .
 
# cd /usr/local/mysql
# cp support-files/my-large.cnf  /etc/my.cnf
#vim /etc/my.cnf
thread_concurrency = 2        //修改此项,我们的cpu为双核的
datadir = /mydata/data        //添加此项,指定数据存放的目录
# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld
# chkconfig --add mysqld
# chkconfig mysqld on

二:为使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,需如下操作
 
#vim/etc/man.config            //输出mysql的man手册至man命令的查找路径
MANPATH  /usr/local/mysql/man     //添加此行
# ln -sv /usr/local/mysql/include  /usr/include/mysql
                           //输出mysql的头文件至系统头文件路径/usr/include
# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf 
                            //输出mysql的库文件给系统库查找路径
# ldconfig            //让系统重新载入系统库
#vim /etc/profile          //修改PATH环境变量,让系统可以直接使用mysql的相关命令
PATH=$PATH:/usr/local/mysql/bin      //添加此行
 
三:实现主从复制
master ip:192.168.1.10
slave ip:192.168.1.11
 
On Master :(在主服务器的操作)
 #vim /etc/my.cnf    确保证如下选项:
 server-id = 1   //主服务器的身份标识
 log-bin=mysql-bin  //开启二进制日志
 sync_binlog=1       //事务提交立即写入到二进制日志
 innodb_flush_logs_at_trx_commit=1 //事务提交之时,立即将二进制日志写入磁盘
 #mysql –uroot –p  
 mysql> grant replication client,replication slave on *.* to cclo@’192.168.1.%’ identified by ‘12345’;
  //此处创建一个用户名为cclo,密码为12345的用户,其权限为client和replication
 mysql> flush privileges;
 mysql> show grants for cclo@’192.168.1.%’; //验证此用户的权限
 
On Slave:(在从服务器的操作)
 #vim /etc/my.cnf
 [mysqld]
 server-id       = 11    // 数值只要保证和Master不同即可
 #log-bin=mysql-bin     //slave的二进制日志一般用不到,暂时关闭
 relay-log=relay-bin    //开启中继日志
 relay-log-index=relay-bin.index
 read_only=1            //此项为阻止普通用户写从服务器
 skip_slave_start=1 
           //mysql服务关闭后,当服务开启时跳过自动启动主从复制(如需自动启动,此项略过)
 #service mysqld restart
 #mysql –uroot –p
 mysql> show master status; 
 +------------------+----------+--------------+------------------+ 
 | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | 
 +------------------+----------+--------------+------------------+ 
 | MySQL-bin.000003 |      374 |              |                  |  
 +------------------+----------+--------------+------------------+ 
 1 row in set (0.00 sec)
mysql> change master to master_host='192.168.1.10',master_user='cclo',master_password='12345',master_log_file='mysql-bin.000003',master_log_pos=374; 
                               //指定Master的ip及复制的用户及二进制日志的位置
 mysq> start slave;                //启动主从复制
 mysql > show slave status;       //查询从服务器的工作属性,确保以下2项
 Slave_IO_Runing: Yes
 Slave_SQL_Runing: Yes        //确保此2项为Yes的状态

linux

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

데이터 백업 및 장애 복구: 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성에 대한 논의 데이터 백업 및 장애 복구: 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성에 대한 논의 Sep 08, 2023 am 09:03 AM

데이터 백업 및 오류 복구: 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성에 대한 논의 소개: 최근 몇 년 동안 데이터 규모와 복잡성이 지속적으로 증가함에 따라 데이터베이스 백업 및 오류 복구가 특히 중요해졌습니다. 분산 시스템에서 MySQL 마스터-슬레이브 복제는 고가용성과 내결함성을 제공하기 위해 클러스터 모드에서 널리 사용됩니다. 이 기사에서는 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성을 살펴보고 몇 가지 코드 예제를 제공합니다. 1. MySQL 마스터-슬레이브 복제의 기본 원리 및 장점 MySQL 마스터-슬레이브 복제는 일반적으로

MySQL 마스터-슬레이브 복제 해독: 클러스터 모드에서 주요 구현 메커니즘 공개 MySQL 마스터-슬레이브 복제 해독: 클러스터 모드에서 주요 구현 메커니즘 공개 Sep 10, 2023 am 09:28 AM

MySQL 마스터-슬레이브 복제 해독: 클러스터 모드에서 주요 구현 메커니즘 공개 소개: 최신 데이터베이스 시스템에서는 데이터의 고가용성과 유연성이 매우 중요합니다. 오픈 소스 관계형 데이터베이스 관리 시스템인 MySQL은 사용자 요구 사항을 충족하는 다양한 애플리케이션을 보유하고 있습니다. MySQL의 마스터-슬레이브 복제는 MySQL 데이터베이스 아키텍처의 매우 중요한 부분이며 데이터 백업 및 고가용성을 달성하는 데 사용됩니다. 이 기사에서는 특히 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 주요 구현 메커니즘을 공개하는 데 중점을 둘 것입니다.

데이터베이스 성능 최적화: 클러스터 기술에서 MySQL 마스터-슬레이브 복제를 사용하는 가장 좋은 방법 데이터베이스 성능 최적화: 클러스터 기술에서 MySQL 마스터-슬레이브 복제를 사용하는 가장 좋은 방법 Sep 10, 2023 am 08:24 AM

데이터베이스 성능 최적화: 클러스터 기술에서 MySQL 마스터-슬레이브 복제를 사용하는 가장 좋은 방법 개요: 인터넷의 급속한 발전으로 인해 데이터베이스 성능 문제는 다양한 기업과 조직의 초점이 되었습니다. MySQL 마스터-슬레이브 복제 기술은 데이터베이스 성능 병목 현상을 해결하는 데 중요한 역할을 합니다. 이 기사에서는 독자가 데이터베이스 성능을 최적화하는 데 도움이 되도록 MySQL 마스터-슬레이브 복제의 개념과 원칙은 물론 클러스터 기술의 최상의 사용 방법을 소개합니다. 1. 서론 데이터의 양이 계속 증가함에 따라 데이터베이스 성능 문제가 점점 더 두드러지고 있습니다. 숫자를 최적화하는 방법

높은 동시성에 쉽게 대처: 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점 분석 높은 동시성에 쉽게 대처: 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점 분석 Sep 10, 2023 pm 03:48 PM

높은 동시성에 쉽게 대처: 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점 분석 인터넷의 급속한 발전으로 인해 웹 사이트 및 애플리케이션에 대한 사용자 방문이 폭발적인 증가 추세를 보였습니다. 동시성이 높은 상황에서 시스템 안정성과 성능을 보장하는 방법은 모든 개발자와 시스템 관리자에게 중요한 과제가 되었습니다. 데이터베이스에서는 MySQL 마스터-슬레이브 복제 기술이 널리 사용되며 높은 동시성을 처리하는 효과적인 솔루션 중 하나가 되었습니다. 이 기사에서는 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점을 살펴보겠습니다. 첫 번째

MySQL 마스터-슬레이브 복제는 클러스터 기술입니까, 아니면 로드 밸런싱 기술입니까? 분석과 차이점 MySQL 마스터-슬레이브 복제는 클러스터 기술입니까, 아니면 로드 밸런싱 기술입니까? 분석과 차이점 Sep 10, 2023 am 08:40 AM

MySQL 마스터-슬레이브 복제는 클러스터 기술입니까, 아니면 로드 밸런싱 기술입니까? 분석 요약 및 차이점: MySQL 마스터-슬레이브 복제는 여러 서버에서 데이터베이스 데이터를 동기화하는 데 사용되는 데이터베이스 복제 기술입니다. 이 기사에서는 기술적 원리, 애플리케이션 시나리오 및 기능적 특성 측면에서 MySQL 마스터-슬레이브 복제, 클러스터 기술 및 로드 밸런싱 기술 간의 차이점을 분석하고 구별합니다. 소개: 최신 인터넷 애플리케이션에서는 데이터베이스의 고가용성과 확장성이 매우 중요합니다. MySQL 마스터-슬레이브 복제는 일반적인 솔루션 중 하나입니다.

클러스터 기술에서 MySQL 마스터-슬레이브 복제의 기능과 장점에 대한 자세한 설명 클러스터 기술에서 MySQL 마스터-슬레이브 복제의 기능과 장점에 대한 자세한 설명 Sep 09, 2023 am 09:03 AM

클러스터 기술에서 MySQL 마스터-슬레이브 복제의 기능과 장점에 대한 자세한 설명 소개 MySQL은 다양한 대규모 웹사이트와 애플리케이션에서 널리 사용되는 강력한 관계형 데이터베이스 관리 시스템입니다. 데이터 양이 증가하고 액세스 요청이 증가함에 따라 단일 MySQL 서버에 대한 부담이 점차 증가합니다. 데이터베이스의 성능과 안정성을 향상시키기 위해 사람들은 클러스터 기술을 채택하기 시작하며 그중 하나는 MySQL 마스터-슬레이브 복제입니다. 일반적으로 사용되는 기술을 의미합니다. MySQL 마스터-슬레이브 복제 원칙 MySQL 마스터-슬레이브 복제는

MySQL 마스터-슬레이브 복제에서 클러스터 기술의 잠재력 발굴: 오픈 소스 솔루션과 상용 솔루션의 비교 평가 MySQL 마스터-슬레이브 복제에서 클러스터 기술의 잠재력 발굴: 오픈 소스 솔루션과 상용 솔루션의 비교 평가 Sep 08, 2023 pm 07:16 PM

MySQL 마스터-슬레이브 복제의 클러스터 기술 잠재력 활용: 오픈 소스 솔루션과 상용 솔루션의 비교 평가 인터넷 비즈니스의 지속적인 발전과 데이터 양의 증가로 인해 데이터베이스 클러스터 솔루션에 대한 수요가 점점 더 커지고 있습니다. MySQL 마스터-슬레이브 복제 기술은 이러한 요구를 충족하며 여러 노드에서 데이터베이스의 읽기 및 쓰기 작업을 개별적으로 처리하여 데이터베이스의 읽기 성능과 가용성을 향상시킵니다. 이 기사에서는 MySQL 마스터-슬레이브 복제에서 클러스터 기술의 잠재력을 살펴보고 오픈 소스 솔루션과 상용 솔루션을 비교 평가합니다.

MySQL 마스터-슬레이브 복제의 클러스터 기능 및 비로드 밸런싱 애플리케이션 시나리오 이해 MySQL 마스터-슬레이브 복제의 클러스터 기능 및 비로드 밸런싱 애플리케이션 시나리오 이해 Sep 11, 2023 am 11:04 AM

인터넷의 급속한 발전과 함께 응용 시스템의 데이터 양이 증가하고 있으며 데이터베이스 성능 및 신뢰성에 대한 요구 사항도 점점 더 높아지고 있습니다. MySQL은 가장 일반적으로 사용되는 오픈소스 관계형 데이터베이스 중 하나로 높은 성능과 안정성을 갖추고 있으며 다양한 기업 수준의 애플리케이션에서 널리 사용되고 있습니다. 일반적으로 사용되는 데이터 복제 솔루션인 MySQL 마스터-슬레이브 복제는 데이터 신뢰성과 읽기 및 쓰기 성능을 향상시킬 수 있으며 대규모 데이터 애플리케이션에 널리 사용됩니다. MySQL 마스터-슬레이브 복제의 클러스터 기능은 복제 메커니즘을 통해 마스터 데이터베이스의 데이터를 동기화하는 것을 의미합니다.

See all articles