mysql 主从数据库复制_Mysql数据库主从复制

需求

在实际生产环境中,如果对数据库的读写都在同一块数据库服务器中操作,无论是在安全性、高可用性,还是高并发等各个方面都是完全不能满足实际需求的

解决方案

一般都是通过主从复制(Master- Slave) 的方式来同步数据,再通过读取分离来提升数据库的并发负载能力

主从复制原理

cde15470de7fe97197280fed879d4695.png

1.在每个事务更新数据完成之前,主服务器在二进制文件记录这些改变,写入二进制日志文件完成后,主服务器通知储存引擎提交事务。

2.Slave将Master的Binary log复制到其中继日志。首先,Slave开始一个工作线程---I/O线程,I/O线程在Master上打开一个普通的连接,然后开始Binlog dump process。Binlog dump process从Master的二进制日志中读取事件,如果已经跟上Master,它会睡眠并等待Master产生新的事件。I/O线程将这些事件写入中继日志。

3.SQL slave thread(SQL从线程)处理该过程的最后一步。SQL线程从中继日志读取事件,并重放其中的事件而更新Slave的数据,使其与Master中的数据一致。只要该线程与I/O线程保持一致,中继日志通常会位于OS的缓存中,所以中继日志的开销很小

实验环境

主机名 操作系统 IP地址 软件包

master CentOS 7.4 192.168.65.138 mysql-5.5.24.tar.gz

Slave1 CentOS 7.4 192.168.65.159 mysql-5.5.24.tar.gz

Slave2 CentOS 7.4 192.168.65.142 mysql-5.5.24.tar.gz

实验目标

实现mysql数据库主从复制

实验步骤

一、建立时间同步环境,在主节点上搭建时间同步服务器

1.安装NTP (系统默认已安装)

2.配置NTP

vim /etc/ntp.conf #添加如下2行

server 127.127.65.0 #本地是时钟源

fudge 127.127.65.0 stratum 8 #设置时间层级为8

3.启动服务

systemctl start ntpd

4.在从节点上进行时间同步

yum install ntp ntpdate -y

/usr/sbin/ntpdate 192.168.65.138 #进行时间同步

5.关闭防火墙,启动服务

systemctl start ntpd.service

systemctl stop firewalld.service

setenforce 0

二、在master,slave1,slave2上安装MySQL数据库

在3个服务器上同时配置:

1.解压软件包

tar zxvf mysql-5.5.24.tar.gz -C /opt/

2.安装环境包

yum install gcc gcc-c++ make cmake ncurses-devel bison libaio-devel -y

3.添加mysql用户并加入到mysql组

useradd -s /sbin/nologin mysql

mkdir /usr/local/mysql

4.编译安装

cd /opt/mysql-5.5.24.tar.gz

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql

-DMYSQL_UNIX_ADDR=/home/mysql/mysql.sock

-DDEFAULT_CHARSET=utf8

-DDEFAULT_COLLATION=utf8_general_ci

-DWITH_EXTRA_CHARSETS=all

-DWITH_MYISAM_STORAGE_ENGINE=1

-DWITH_INNOBASE_STORAGE_ENGINE=1

-DWITH_MEMORY_STORAGE_ENGINE=1

-DWITH_READLINE=1

-DENABLED_LOCAL_INFILE=1

-DMYSQL_DATADIR=/home/mysql

-DMYSQL_USER=mysql

-DMYSQL_TCP_PORT=3306

make & make install

5.修改mysql安装目录的所有者,所属组

chown -R mysql.mysql /usr/local/mysql

6.优化调整

export PATH=$PATH:/usr/local/mysql/bin/ \*开机时刷新*\

cp support-files/my-medium.cnf /etc/my.cnf

cp support-files/mysql.server /etc/init.d/mysqld

chmod 755 /etc/init.d/mysqld

chkconfig --add /etc/init.d/mysqld

chkconfig mysqld --level 35 on

7.初始化数据库

/usr/local/mysql/scripts/mysql_install_db \

--user=mysql \

--ldata=/var/lib/mysql \

--basedir=/usr/local/mysql \

--datadir=/home/mysql

8.直接建立软连接

ln -s /var/lib/mysql/mysql.sock /home/mysql/mysql.sock

9.修改配置文件

vi /etc/init.d/mysqld

basedir=/usr/local/mysql

datadir=/home/mysql

三.配置主服务器

1.修改配置文件

vim /etc/my.cnf

server-id = 11 #id号是唯一的,不能与其他服务器相同

log-bin=master-bin #主服务器日志文件

log-slave-updates=true #从服务器更新二进制日志

2.重启mysql服务器

systemctl restart mysqld.service

3.登录mysql,给从服务器授权

mysql -u root -p #登录mysql

GRANT REPLICATION SLAVE ON *.* TO 'myslave'@'192.168.65.%' IDENTIFIED BY '123456'; #给从服务器授权复制权限

FLUSH PRIVILEGES; #刷新,让设置生效

4.查看主服务器状态

d9b3f023bb03067600c14a07cd78a57c.png

四.从服务器slave1配置

1.修改配置文件

vim /etc/my.cnf

server-id = 22 # id号不能与其他服务器相同

relay-log=relay-log-bin #从主服务器上同步日志文件记录到本地

relay-log-index=slave-relay-bin.index #定义relay-log的位置和名称

2..登录mysql,设置主从同步

mysql -u root -p #登录mysql

change master to master_host='192.168.65.159',master_user='myslave',

master_password='123456',master_log_file='master-bin.000002',master_log_pos=339; #设置与主服务器同步

start slave; #开启同步

show slave status\G; #查看状态

Slave_IO_Running: Yes #yes表示io连接成功

Slave_SQL_Running: Yes #yes表示mysql进程同步连接成功

五.从服务器slave2配置

1.修改配置文件

vim /etc/my.cnf

server-id = 33 # id号不能与其他服务器相同

relay-log=relay-log-bin #从主服务器上同步日志文件记录到本地

relay-log-index=slave-relay-bin.index #定义relay-log的位置和名称

2..登录mysql,设置主从同步

mysql -u root -p #登录mysql

change master to master_host='192.168.65.142',master_user='myslave',

master_password='123456',master_log_file='master-bin.000002',master_log_pos=339; #设置主从同步

start slave; #开启同步功能

show slave status\G #纵向查看同步连接状态

Slave_IO_Running: Yes #yes表示io连接成功

Slave_SQL_Running: Yes #yes表示mysql进程同步连接成功

六.验证主从同步

1.在主服务器上 create database hhhh;

5df2b1b4beffb37939fa19a30e3d10e4.png

2.去从服务器1上 show databases;

76076e4c994aacae6e1b8a4260e26753.png

3.去从服务器2上 show databases;

3736195c5a0862b5bc12a09171576f2f.png

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值