温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Mysql数据库的主从复制是怎样的

发布时间:2021-09-28 11:42:41 来源:亿速云 阅读:140 作者:柒染 栏目:MySQL数据库

这篇文章将为大家详细讲解有关Mysql数据库的主从复制是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

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

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

主从复制原理
Mysql数据库的主从复制是怎样的

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.查看主服务器状态
Mysql数据库的主从复制是怎样的

四.从服务器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;
Mysql数据库的主从复制是怎样的

2.去从服务器1上 show databases;
Mysql数据库的主从复制是怎样的

3.去从服务器2上 show databases;
Mysql数据库的主从复制是怎样的

关于Mysql数据库的主从复制是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI