#mysql数据库 #主从
MySQL数据库主从配置
1.MySQL主从介绍
MySQL 主从又叫做 Replication、AB 复制。简单讲就是 A 和 B 两台机器做主
从后,在 A 上写数据,另外一台 B 也会跟着写数据,两者数据实时同步的。
MySQL 主从是基于 binlog 的,主上须开启 binlog 才能进行主从。
主从过程大致有 3 个步骤:
1)主将更改操作记录到 binlog 里
2)从将主的 binlog 事件(sql 语句)同步到从本机上并记录在 relaylog
里中继日志
3)从根据 relaylog 里面的 sql 语句按顺序执行
主配置(安装完 mysql 的虚拟机)
一台IP:192.168.13.5 我将这台虚拟机作为我的主服务器
一台IP:192.168.13.8 我将这台虚拟机作为我的从服务器
基础配置:
[root@localhost ~]# vi /etc/my.cnf进入MySQL的编辑文件
data:image/s3,"s3://crabby-images/f2ad9/f2ad991ff170c74a68865dcc281d7b9e6ac0c598" alt=""
重启mysqld服务:(两种都可以)
错误:出现错误之后,可以查看MySQL的进程,如果有的话,请先全部kill掉
ps aux | grep mysql *kill -9 进程数据
[root@localhost ~]# /etc/init.d/mysqld restart
[root@localhost ~]# systemctl start mysqld.service
备份MySQL库(加入环境变量)
[root@localhost ~]# mysqldump -uroot mysql > /tmp/mysql.sql 输入该命令之后会存在命令不存在,可以通过添加mysql的环境变量
data:image/s3,"s3://crabby-images/ac1f4/ac1f47635be860d876df51f9bd58ef1d2609b710" alt=""
data:image/s3,"s3://crabby-images/b0d7e/b0d7e54852e00ec7ae7267387db1f414815db378" alt=""
创建一个库保存数据(此库为同步库)
[root@localhost ~]# mysqldump -uroot -e "create database kei"
将MySQL库恢复成新建的库,作为测试数据,进行数据库配置
[root@localhost ~]# mysql -uroot进入数据库,创建同步数据的用户赋予权限
mysql> grant replication slave on *.* to 'repl' @192.168.13.5 identified by '204718';
data:image/s3,"s3://crabby-images/c52ce/c52cee20de94d8148f7f9bc4848ed05096742d50" alt=""
提醒:此次进入的仅此为数据库,可以使用use MySQL或者是其他进入数据库,若是要进入MySQL数据库一定要进去,因为MySQL本身就含有一个MySQL数据库
将表锁住,保持表内的数据不变
mysql> flush tables with read lock;
data:image/s3,"s3://crabby-images/a6660/a6660abbe3c76da1050a1ea7b8f5419e10d8ab42" alt=""
显示主机的状态
mysql> show master status;
data:image/s3,"s3://crabby-images/77b15/77b15e34b97daaf107fdf2c90c3e220442ab0543" alt=""
错误:这里一定要细心,要不然很有可能出现主机状态为空,配置MySQL文件的时候需要注释掉和需要留存的要分清楚,尤其是主配置中添加配置文件的时候。我们可以通过,ls -/data/mysql 查看有错误的地方(含有err即为错误日志)[root@localhost ~]# tail -15 /data/mysql/aminglinux.000001用这个命令查看错误日志。其中/data/mysql就是存放mysql数据库,后面就是二进制日志。
data:image/s3,"s3://crabby-images/19531/19531a6080519b1039955dce9db96518bb171645" alt=""
data:image/s3,"s3://crabby-images/fb3bd/fb3bdf376acb23a7c233b6d874239b634896c6af" alt=""
从配置(安装完mysql的虚拟机)
基础配置:
[root@localhost ~]# vi /etc/my.cnf进入MySQL的编辑文件
data:image/s3,"s3://crabby-images/f66fd/f66fd85d5868ff7d1e8eb20034bfd352b6de59f5" alt=""
重启mysqld服务:(两种都可以)
[root@localhost ~]# /etc/init.d/mysqld restart
[root@localhost ~]# systemctl start mysqld.service
错误:出现错误之后,可以查看MySQL的进程,如果有的话,请先全部kill掉
ps aux | grep mysql *kill -9 进程数据
在主服务器上将文件拷贝到从上,并在从上查看两者的文件大小是否一致
[root@localhost ~]# scp /tmp/mysql.sql root@192.168.13.8:/tmp/这里填写的IP为从的
[root@localhost ~]# ls -la /tmp/mysql.sql
data:image/s3,"s3://crabby-images/dd89f/dd89fbbc9281d3df10348021fa102dbc1d7ba57b" alt=""
创建一个和主一样的库
[root@localhost ~]# mysqldump -uroot -e "create database kei"
data:image/s3,"s3://crabby-images/8b29a/8b29a0bcac4e1aab6b68d7e2b4bd117cf3dfea8a" alt=""
将文件的内容导入库
[root@localhost ~]# mysql -uroot kei < /tmp/mysql.sql
[root@localhost ~]# mysql -uroot进入数据库,配置数据库
错误:此时的IP等一系列,要求的都是为主服务器的,log_file和log_pos都通过主配置的显示主机状态中得到。
data:image/s3,"s3://crabby-images/21c93/21c9365e97e0f8ba73ac938683b4027d1e186b2b" alt=""
在主上面执行解锁表
[mysql] > unlock tables;
data:image/s3,"s3://crabby-images/967b0/967b0fe40b0f556c465b73c342deaf68c7fc22ad" alt=""
进行验证的时候,需要刷新
主从同步以及相关配置参数
在从服务器上操作并执行命令,关闭防火墙
[mysql]>systemctl stop firewalld
[mysql]>setenforce 0
[mysql ]> show slave statusG
data:image/s3,"s3://crabby-images/dcb13/dcb138904d78442e17c4e723ef33dee8163aa445" alt=""
data:image/s3,"s3://crabby-images/5e2d8/5e2d83ce03aa0abe9661912c60253fda9059082a" alt=""
出现上面的这种即为正确的,表示配置正常。
data:image/s3,"s3://crabby-images/0a273/0a273d64b7446d57de540ce658aced1a4db7ac1e" alt=""
data:image/s3,"s3://crabby-images/ef96f/ef96f3fc32afe4b4fefd6dfbc530b4f836897257" alt=""
配置参数
[root@localhost~]# vi /etc/my.cnf从
data:image/s3,"s3://crabby-images/fc574/fc57446ae806810dd88fa254626d955cf1501c95" alt=""
[root@localhost~]# vi /etc/my.cnf主
data:image/s3,"s3://crabby-images/6f14a/6f14a00343e3761ae43a0a31e1ff0742b87e57a4" alt=""
测试主从
主:进入同步的数据库(注意MySQL的本身含有MySQL数据库)
[root@localhost ~]# mysql -uroot
mysql> use kei由于我创建的用来同步的库为kei
mysql> select count(*)from db;
data:image/s3,"s3://crabby-images/6906f/6906f38677cfbbc3dfe4d74fe32f9432f6ec9947" alt=""
从:
[root@localhost ~]# mysql -uroot
mysql> use kei
mysql> select count(*)from db;
data:image/s3,"s3://crabby-images/8a5f2/8a5f214e54d2a81be2b1ae70b8cec6a1daf49f24" alt=""