搭建mysql主从服务器

搭建mysql主从服务器

前言

为什么要搭建mysql主从服务器

  1. 在传统仅有单个mysql服务器的项目中,一旦同时间遇到大量用户对数据库进行速写操作,服务器就就很容易宕机,进而导致数据丢失,这种原因是由于数据库无法有效处理高并发写入请求,导致资源耗尽,响应时间延长甚至崩溃.因此,就有必要采用多服务器协同解决大量请求的问题,减轻单台服务器的压力。

MySQL主从服务器原理(1主1从为例)

在这里插入图片描述

binlog日志文件相关操作

序号sql语句解释
1show variables like ‘log_bin’;查看日志是否启用
2show variables like ‘%datadir%’;查看binlog所在位置
3show binary logs;显示所有日志文件
4show binlog events in ‘日志名’;查看binlog日志

如上图所示,我们先分别创建两个docker容器挂载mysql分别扮演主服务器(master),从服务器(slave)

  • 主服务器是主要的数据库服务器,负责处理写(增删改)和读(查)的操作
  • 当主服务器收到读写操作时,这些操作记录将被记录在二进制日志文件binlog里,称为二进制日志事件(Binary Log Events )。
  • 从服务器通过开启IOthread读取binlog中的操作记录,并开启IOtrread中的写线程写入slave服务器的relayLog文件中
  • 从服务器开启SQLthread,读取rapayLog文件中的数据,进而更新数据库中的内容,从而实现主服务器和从服务器间数据的同步

此外,mysql主从赋不仅局限为1主1从,还可以配置1主多从,以满足不同需求,接下来我们来看看mysql主从服务器的搭建过程。

mysql主从服务器搭建(1主2从为例)

创建存储文件夹

在这里插入图片描述

从容器中拷贝原始的my.cnf配置文件

  • 先创建一个基础docker容器

  • cd /usr/local/software/mysql/3306/conf 来到需要拷贝原始my.cnf的目录下

  • ./ —当前位置

  • docker cp 容器名称: 文件地址 目标地址

  • 再将容器内/etc/mysql/my.cnf 拷贝到当前位置

    docker run -it --name mytest -e MYSQL_ROOT_PASSWORD=123 -d mysql
    docker cp mytest:/etc/mysql/my.cnf ./
    

搭建主(master)服务器

docker run \
-it \
--name mysql_3306 \
--privileged \
--network wn_docker_net \
--ip 172.18.12.2 \
-p 3306:3306 \
-v  /usr/local/software/mysql/3306/conf/my.cnf:/etc/mysql/my.cnf \
-v  /usr/local/software/mysql/3306/data:/var/lib/mysql \
-v /usr/local/software/mysql/3306/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123 \
-d mysql

测试客户端Navicat能否成功连接

在这里插入图片描述

master服务器配置my.cnf

# Custom config should go here
server-id=200    #server‘id
log_bin=wnhz-master-logbin    #logbin name
binlog_format=row

vim 文本编辑器

  • i: 插入
  • esc :退出编辑
  • :wq – 退出并储存
  • 插入完成后需要重启docker容器才能生效

查看master服务器状态

show master status;

在这里插入图片描述

搭建从服务器(slave)

docker run \
-it \
--name mysql_3310 \
--privileged \
--network wn_docker_net \
--ip 172.18.12.3 \
-p 3310:3306 \
-v  /usr/local/software/mysql/3310/conf/my.cnf:/etc/mysql/my.cnf \
-v  /usr/local/software/mysql/3310/data:/var/lib/mysql \
-v /usr/local/software/mysql/3310/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=123 \
-d mysql

master创建用户slave进行主从关联

create user 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123';
GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO 'slave'@'%';
flush privileges;

在这里插入图片描述

进入slave容器并连接mysql

change master to master_host='172.18.12.2', master_user='slave',master_password='123',MASTER_LOG_FILE='wnhz-master-logbin.000002',MASTER_LOG_POS=156;

启动slave复制

start slave;

查询slave状态

show slave status \G;

在这里插入图片描述

出现两个yes即配置成功

配置异常处理

主从设置中出现不是两个yes
  • 先关闭slave

    stop slave
    
  • 重置slave中的replaylog

    reset slave;
    
  • 重新配置

show master status;    #查看maseter主容器状态

change master to master_host='172.18.12.2', master_user='slave',master_password='123',MASTER_LOG_FILE='wnhz-master-logbin.000001',MASTER_LOG_POS=156;  #slave
  • 重新运行slave

    start slave;
    
客户端连接不上mysql

出现这种问题多是电脑的安全级别太高导致的,以下是两种解决方案

  1. 永久关闭防火墙

    sudo systemctl disable iptables
    
  2. 防火墙开启指定端口

    firewall-cmd --add-ports=3306/tcp --permanent 
    firewall-cmd --reload
    firewall-cmd --list-ports 
    

创建只读账号

为了进一步维护数据库的完整性,安全性和性能,在实际应用中,我们往往需要创建特定权限的用户。

创建权限为读操作的用户

create user 'asd'@'%' IDENTIFIED WITH mysql_native_password BY '123';
GRANT SELECT ON *.* TO 'asd'@'%';
flush privileges;

附录

master主服务器my.cnf配置

[mysqld]
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
datadir         = /var/lib/mysql
secure-file-priv= NULL
default_authentication_plugin=mysql_native_password
# Custom config should go here
!includedir /etc/mysql/conf.d/

server-id=200    #server‘id
log_bin=wnhz-master-logbin    #logbin name
binlog_format=row

slave从服务器my.cnf配置

[mysqld]
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
datadir         = /var/lib/mysql
secure-file-priv= NULL
default_authentication_plugin=mysql_native_password
# Custom config should go here
!includedir /etc/mysql/conf.d/
server-id=201    #slave‘id
log_bin=wnhz-slave-01-logbin    #logbin name
relay_log=wnhz-slave-01-relay
read-only=1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值