목차
安装准备
安装MySQL
初始化MySQL
管理MySQL安全性
配置Master和Slave之间的复制
데이터 베이스 MySQL 튜토리얼 MySQL的Master/Slave集群安装和配置_MySQL

MySQL的Master/Slave集群安装和配置_MySQL

Jun 01, 2016 pm 01:02 PM
무리

本文讲述MySQL的Master/Slave集群安装和配置,安装的版本是最新的稳定版本GA 5.6.19。

为了支持有限的HA,我们使用Master/Slave简单的读写分离集群。有限的HA是指当Master不可用时,数据不会丢失,但在Master宕机的情况下是不可写的,必须手工处理故障。如果要支持更高的可用性,可以使用两台Master来做热切换。

Master和Slave的MySQL安装是相同的,只是my.cnf的配置不同,需要配置二进制日志文件复制。

没有特殊说明,命名中带#的为root用户操作,带$的为mysql Linux用户的操作。

安装准备

1. 在安装MySQL前,需要确认下面的系统软件已经安装在Linux中。

软件名称

软件描述

gcc-4.4.7

编程语言编译器

gcc-c++-4.4.7

C++语言编译器

cmake-2.6.4-5

跨平台的开源构建系统

ncurses-devel-5.7-3.20090208

控制打印控制台屏幕

2. 创建mysql Linux用户

# groupadd mysql

# useradd -g mysql mysql

# passwd mysql

3. 准备安装目录

创建MySQL安装目录,并赋权限给mysql用户:

# mkdir /usr/local/mysql-5.6.19

# chown mysql:mysql /usr/local/mysql-5.6.19

# chmod -R 770 /usr/local/mysql-5.6.19

4. 创建MySQL数据存储目录:

# mkdir /data

# mkdir /data/mysql

# chown mysql:mysql /data/mysql

5. 授权MySQL解压源码目录/usr/local/src目录的可执行权限给所有用户:

# chmod -R 757 /usr/local/src

安装MySQL

1. 解压缩安装包:

$ cd /usr/local/src

$ tar -xzvf mysql-5.6.19.tar.gz

2. 配置MySQL编译参数

$ cd /usr/local/src/mysql-5.6.19

$ cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.6.19\

-DMYSQL_DATADIR=$MYSQL_DATA_PATH\

-DSYSCONFDIR=/usr/local/mysql-5.6.19/conf\

-DDEFAULT_CHARSET=utf8\

-DDEFAULT_COLLATION=utf8_general_ci\

-DWITH_READLINE=1\

-DWITH_INNOBASE_STORAGE_ENGINE=1\

-DWITH_ARCHIVE_STORAGE_ENGINE=1 \

-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

-DWITH_PERFSCHEMA_STORAGE_ENGINE=1

备注:

-DCMAKE_INSTALL_PREFIX: 配置MySQL的安装目录。

-DMYSQL_DATADIR: 配置MySQL的数据目录。

-DSYSCONFDIR: 配置MySQL的配置文件目录。

-DDEFAULT_CHARSET: 默认字符集。

-DDEFAULT_COLLATION:设定默认语言的排序规则。

-DWITH_READLINE:支持批量导入mysql数据。

-DWITH_INNOBASE_STORAGE_ENGINE:使用INNOBASE存储引擎。

-DWITH_ARCHIVE_STORAGE_ENGINE:常应用于日志记录和聚合分析,不支持索引。

-DWITH_BLACKHOLE_STORAGE_ENGINE:黑洞存储引擎。

-DWITH_PERFSCHEMA_STORAGE_ENGINE:性能模式引擎。

3. 执行make

$ make

$ make install

4. 修改myql用户的环境变量,增加MYSQL_HOME,并把bin加到PATH:

$ vi ~/.bash_profile

在文件中增加蓝色字体部分:

# User specific environment and startup programs

# MySQL home目录

export MYSQL_HOME=/usr/local/mysql-5.6.19

 

PATH=$PATH:$HOME/bin:$MYSQL_HOME/bin

 

export PATH

$ source ~/.bash_profile

初始化MySQL

1. 安装service脚本

# cp /usr/local/mysql-5.6.19/support-files/mysql.server/etc/init.d/mysqld

# chown mysql:mysql/etc/init.d/mysqld

# chmod 700 /etc/init.d/mysqld

2. 创建mysql权限数据库

$ $MYSQL_HOME/scripts/mysql_install_db--basedir=$MYSQL_HOME --datadir=/data/mysql

3. 创建PID文件目录

$ mkdir $MYSQL_HOME/var

4. 为master配置my.cnf

my.cnf格式不正确,很容易在启动时错误,最好在原有文件的基础上通过vi工具在linux上修改。

如果文件已经损坏,可以通过默认的模板中拷贝:

$ cp $MYSQL_HOME/support-files/my-default.cnf$MYSQL_HOME/my.cnf

编辑my.cnf

$ vi $MYSQL_HOME/my.cnf

在文件中增加蓝色字体部分:

# For advice on how to change settings please see

# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html

[mysqld]

# Remove leading # and set to the amount of RAM for the most important data

# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.

innodb_buffer_pool_size = 256M

innodb_flush_log_at_trx_commit=1

# Remove leading # to turn on a very important data integrity option: logging

# changes to the binary log between backups.

log_bin=master-bin

log_bin_index=master-bin.index

# These are commonly set, remove the # and set as required.

# basedir = .....

datadir = /data/mysql

port = 3306

# first master server id

server_id = 1

socket = /tmp/mysql.sock

pid-file = /usr/local/mysql-5.6.19/var/master.pid

# Remove leading # to set options mainly useful for reporting servers.

# The server defaults are faster for transactions and fast SELECTs.

# Adjust sizes as needed, experiment to find the optimal values.

# join_buffer_size = 128M

# sort_buffer_size = 2M

# read_rnd_buffer_size = 2M

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES


5. 为slave配置my.cnf

和master的配置文件一样进行修改,但注意文件中的log文件名、datadir和server_id等内容不同。

编辑my.cnf

$ vi $MYSQL_HOME/my.cnf

在文件中增加蓝色字体部分:

# For advice on how to change settings please see

# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html

[mysqld]

# Remove leading # and set to the amount of RAM for the most important data

# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.

innodb_buffer_pool_size = 256M

innodb_flush_log_at_trx_commit=1

# Replication

# relay-log=slave-relay-bin

# relay-log-index=slave-relay-bin.index

# These are commonly set, remove the # and set as required.

# basedir = .....

datadir = /data/mysql

port = 3306

# first slave server id of master 1

server_id = 101

socket = /tmp/mysql.sock

pid-file = /usr/local/mysql-5.6.19/var/slave.pid

# Remove leading # to set options mainly useful for reporting servers.

# The server defaults are faster for transactions and fast SELECTs.

# Adjust sizes as needed, experiment to find the optimal values.

# join_buffer_size = 128M

# sort_buffer_size = 2M

# read_rnd_buffer_size = 2M

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES


6. 启动MySQL

启动和停止master和slave都完全一样。

$ service mysqldstart

通过下面命令查看是否启动成功:

$ service mysqldstatus

7. 停止MySQL

$ service mysqld stop

管理MySQL安全性

默认MySQL的root的用户密码为空,为了提高安全性,应该设置root用户一个安全的密码。

在服务器上通过mysql用户打开MySQL客户端:

$ mysql –u root

设置一个安全的密码:

mysql> SET PASSWORD FORroot@localhost=PASSWORD('secret');

配置Master和Slave之间的复制

1. 创建执行复制的MySQL用户

在Master上创建一个复制用户,其中secret为用户的密码:

mysql> CREATEUSER repl_user IDENTIFIED BY 'secret';

并赋给复制权限:

mysql>GRANTREPLICATION SLAVE ON *.* TO repl_user;

2. 锁定Master并获取二进制日志位置值

获取读锁:

mysql> FLUSH TABLES WITHREAD LOCK;

显示当前二进制文件名及位置值:

mysql> SHOW MASTER STATUS;

\

3. 通过mysqldump工具获取Master数据快照

在另外一个会话中在Master上执行:

$ mysqldump -u root-p --all-databases --master-data > data_dump.sql

执行后,保存在当前目录中。

4. 释放Master上的读锁

在获取读锁的会话中,执行释放锁命令:

mysql> UNLOCK TABLES;

5. 导入dump数据到Slave中 

通过scp拷贝data_dump.sql到Slave的机器上。

$ scp data_dump.sqlmysql@:/home/mysql

在Slave上通过下面的命令导入到Slave的MySQL中。

$ mysql –u root -p

mysql> source data_dump.sql;

6. 配置Master和Slave之间的复制

mysql> CHANGE MASTER TO MASTER_HOST='',

MASTER_USER='repl_user',

MASTER_PASSWORD='secret',

MASTER_PORT = 3306,

MASTER_LOG_FILE='master-bin.000003',

MASTER_LOG_POS=881;

上面的MASTER_LOG_FILE和MASTER_LOG_POS需要配置6.2中查询到的信息。是Master的IP或主机名。

启动Slave:

mysql> START SLAVE;

7. 验证Master和Slave的状态

在Master上执行:

mysql> SHOW MASTER STATUS;

\

在Slave上执行:

mysql> SHOW SLAVE STATUS;

\

上面信息显示没有任何错误,Slave_IO_State信息为‘Waitigfor master to send event’,说明复制连接配置OK。

至此,两个MySQL的Master/Slave模式的集群已经部署成功,可以在Master上执行数据更新操作,发现可以正常复制到Slave上。

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

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

노드는 Proxmox VE에서 완전히 대피하고 클러스터에 다시 합류합니다. 노드는 Proxmox VE에서 완전히 대피하고 클러스터에 다시 합류합니다. Feb 21, 2024 pm 12:40 PM

ProxmoxVE에서 노드를 완전히 제거하고 클러스터에 다시 합류하는 시나리오 설명 ProxmoxVE 클러스터의 노드가 손상되어 신속하게 복구할 수 없는 경우 결함이 있는 노드를 클러스터에서 완전히 추방하고 잔여 정보를 정리해야 합니다. 그렇지 않으면 결함이 있는 노드가 사용하는 IP 주소를 사용하는 새 노드는 클러스터에 정상적으로 합류할 수 없습니다. 마찬가지로 클러스터에서 분리된 결함이 있는 노드가 복구된 후에는 클러스터와 관련이 없지만 이 단일 노드의 웹 관리에 액세스할 수 없습니다. 백그라운드에서 원래 ProxmoxVE 클러스터의 다른 노드에 대한 정보가 표시되므로 매우 짜증납니다. 클러스터에서 노드를 제거합니다. ProxmoxVE가 Ceph 하이퍼 수렴형 클러스터인 경우 호스트 시스템 Debian에서 클러스터의 모든 노드(삭제하려는 노드 제외)에 로그인하고 명령을 실행해야 합니다.

PHP 고동시성 환경에서 데이터베이스 최적화 방법 PHP 고동시성 환경에서 데이터베이스 최적화 방법 Aug 11, 2023 pm 03:55 PM

PHP 높은 동시성 환경에서 데이터베이스 최적화 방법 인터넷의 급속한 발전으로 인해 점점 더 많은 웹사이트와 애플리케이션이 높은 동시성 문제에 직면해야 합니다. 이 경우 데이터베이스 성능 최적화가 특히 중요하며, 특히 PHP를 백엔드 개발 언어로 사용하는 시스템의 경우 더욱 그렇습니다. 이 기사에서는 PHP 높은 동시성 환경에서 몇 가지 데이터베이스 최적화 방법을 소개하고 해당 코드 예제를 제공합니다. 연결 풀링 사용 동시성이 높은 환경에서는 데이터베이스 연결을 자주 생성하고 삭제하면 성능 병목 현상이 발생할 수 있습니다. 따라서 연결 풀링을 사용하면

Docker를 사용하여 다중 노드 클러스터를 관리하고 확장하는 방법 Docker를 사용하여 다중 노드 클러스터를 관리하고 확장하는 방법 Nov 07, 2023 am 10:06 AM

오늘날의 클라우드 컴퓨팅 시대에 컨테이너화 기술은 오픈 소스 세계에서 가장 인기 있는 기술 중 하나가 되었습니다. Docker의 등장으로 클라우드 컴퓨팅은 더욱 편리하고 효율적이게 되었으며, 개발자와 운영 및 유지 관리 담당자에게 없어서는 안 될 도구가 되었습니다. 다중 노드 클러스터 기술의 적용은 Docker 기반으로 널리 사용됩니다. 다중 노드 클러스터 배포를 통해 리소스를 보다 효율적으로 활용하고, 안정성과 확장성을 향상시키며, 배포 및 관리에 있어 보다 유연해질 수 있습니다. 다음으로 Docker를 사용하는 방법을 소개하겠습니다.

PHP의 일반적인 클러스터는 무엇입니까? PHP의 일반적인 클러스터는 무엇입니까? Aug 31, 2023 pm 05:45 PM

PHP의 일반적인 클러스터에는 LAMP 클러스터, Nginx 클러스터, Memcached 클러스터, Redis 클러스터 및 Hadoop 클러스터가 포함됩니다. 자세한 소개: 1. LAMP 클러스터는 Linux, Apache, MySQL 및 PHP의 조합을 의미합니다. LAMP 클러스터에서는 여러 서버가 동일한 애플리케이션을 실행하고 로드 밸런서를 통해 균형을 유지합니다. 2. Nginx 클러스터, Nginx는 고성능 웹 서버 등입니다.

MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법 MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법 Sep 19, 2023 pm 01:22 PM

MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법 소개: 오늘날 빅 데이터 시대에 데이터 볼륨의 급속한 증가로 인해 데이터베이스 성능에 대한 요구 사항이 높아졌습니다. 이러한 요구 사항을 충족하기 위해 데이터 클러스터링과 로드 밸런싱은 필수적인 기술적 수단이 되었습니다. 성숙한 NoSQL 데이터베이스인 MongoDB는 데이터 클러스터링 및 로드 밸런싱을 지원하는 풍부한 기능과 도구를 제공합니다. 이 기사에서는 MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법을 소개하고 특정 코드를 제공합니다.

Workerman 문서의 서버 클러스터 구현 방법 Workerman 문서의 서버 클러스터 구현 방법 Nov 08, 2023 pm 08:09 PM

Workerman은 PHP가 비동기 네트워크 통신을 보다 효율적으로 처리할 수 있게 해주는 고성능 PHPSocket 프레임워크입니다. Workerman의 문서에는 서버 클러스터를 구현하는 방법에 대한 자세한 지침과 코드 예제가 있습니다. 서버 클러스터를 구현하기 위해서는 먼저 서버 클러스터의 개념을 명확히 해야 합니다. 서버 클러스터는 여러 서버를 네트워크에 연결하여 로드와 리소스를 공유함으로써 시스템 성능, 안정성 및 확장성을 향상시킵니다. Workerman에서는 다음 두 가지 방법을 사용할 수 있습니다.

MySQL 클러스터 배포 및 유지 관리 프로젝트 경험 요약 MySQL 클러스터 배포 및 유지 관리 프로젝트 경험 요약 Nov 02, 2023 pm 01:33 PM

MySQL 클러스터 배포 및 유지 관리 프로젝트 경험 요약 MySQL은 인터넷 애플리케이션 개발에서 가장 일반적으로 사용되는 데이터베이스 중 하나입니다. 비즈니스 규모가 계속 확장됨에 따라 독립형 MySQL은 더 이상 수요를 충족할 수 없습니다. 데이터베이스의 성능과 용량을 확장하는 MySQL 클러스터 솔루션입니다. 이 문서에서는 모든 사람의 MySQL 클러스터 배포 및 유지 관리 작업에 도움이 되기를 바라며 MySQL 클러스터 배포 및 유지 관리 프로세스에서 배운 경험과 교훈을 요약합니다. 1. MySQL 클러스터 MySQL 클러스터의 배포 및 아키텍처 설계

MySQL 데이터베이스의 클러스터 환경을 구성하는 방법은 무엇입니까? MySQL 데이터베이스의 클러스터 환경을 구성하는 방법은 무엇입니까? Jul 12, 2023 pm 02:52 PM

MySQL 데이터베이스의 클러스터 환경을 구성하는 방법은 무엇입니까? 서문: 인터넷의 발달과 데이터 양의 지속적인 증가로 인해 데이터베이스는 모든 기업에 필요한 핵심 시스템 중 하나가 되었습니다. 동시에 높은 데이터 가용성과 읽기 및 쓰기 성능 요구 사항을 보장하기 위해 데이터베이스 클러스터 환경은 점차 기업의 선택이 되었습니다. 이 글에서는 MySQL 데이터베이스의 클러스터 환경을 구성하는 방법을 소개하고 해당 코드 예제를 제공합니다. 1. 환경 준비 MySQL 데이터베이스의 클러스터 환경을 구성하기 전에 다음과 같은 환경 준비가 완료되었는지 확인해야 합니다. M 설치

See all articles