Mysql主从搭建

Posted Palpitate

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql主从搭建相关的知识,希望对你有一定的参考价值。

# 1 主从同步的流程或原理
    1)master会将变动记录到二进制日志里面;
    2)master有一个I/O线程将二进制日志发送到slave;
    3) slave有一个I/O线程把master发送的二进制写入到relay日志里面;
    4)slave有一个SQL线程,按照relay日志处理slave的数据;
# 2 



# 3 修改配置文件
####主库的配置文件,server-id和开启binlog日志
[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000
server-id=100  
log-bin=mysql-bin
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8




#############从库的配置
####主库的配置文件,server-id和开启binlog日志
[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000
server-id=101 
log-bin=mysql-slave-bin
relay_log=edu-mysql-relay-bin
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

# 4 拉起两个mysql容器
#启动主库容器(挂载外部目录,端口映射成33307,密码设置为123456)
docker run  -di -v /home/mysql/data/:/var/lib/mysql -v /home/mysql/conf.d:/etc/mysql/conf.d -v /home/mysql/my.cnf:/etc/mysql/my.cnf -p 33307:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
#启动从库容器(挂载外部目录,端口映射成33306,密码设置为123456)
docker run  -di -v /home/mysql2/data/:/var/lib/mysql -v /home/mysql2/conf.d:/etc/mysql/conf.d -v /home/mysql2/my.cnf:/etc/mysql/my.cnf -p 33306:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
                    
                    
#5  创建test用户,并授权
#在主库创建用户并授权
##创建test用户
create user \'test\'@\'%\' identified by \'123\';
##授权用户
grant all privileges on *.* to \'test\'@\'%\' ;
###刷新权限
flush privileges;
#查看主服务器状态(显示如下图)
show master status;
# 可以看到日志文件的名字,和现在处在哪个位置


#6 连接从库,配置连接主库
#连接从库
mysql -h 172.16.209.100 -P 33306 -u root -p123456
#配置详解
/*
change master to 
master_host=\'MySQL主服务器IP地址\', 
master_user=\'之前在MySQL主服务器上面创建的用户名\', 
master_password=\'之前创建的密码\', 
master_log_file=\'MySQL主服务器状态中的二进制文件名\', 
master_log_pos=\'MySQL主服务器状态中的position值\';
*/
#命令如下
change master to master_host=\'101.133.225.166\',master_port=33307,master_user=\'test\',master_password=\'123\',master_log_file=\'mysql-bin.000003\',master_log_pos=0;
#启用从库
start slave;
#查看从库状态(如下图)
show slave status\\G;
####这两个是yes表示配成功
   Slave_IO_Running: Yes
   Slave_SQL_Running: Yes

# 7 测试
#在主库上创建数据库test1
create database test1;
use test1;
#创建表
create table tom (id int not null,name varchar(100)not null ,age tinyint);
#插入数据
insert tom (id,name,age) values(1,\'xxx\',20),(2,\'yyy\',7),(3,\'zzz\',23);

 

以上是关于Mysql主从搭建的主要内容,如果未能解决你的问题,请参考以下文章

如何搭建mysql的主从关系

MYSQL主从同步搭建

MySQL 运维 主从复制 -- 主从复制概述主从复制原理搭建MySQL主从复制

MySQL主从复制的简单搭建

MySQL主从复制的简单搭建

MySQL主从复制的简单搭建