Mysql的主从复制及扩展功能

一、配置过程

1.配置master

vim /etc/my.cnf

mysqld

datadir=/data/mysql 指定数据库文件的存储位置

socket=/data/mysql/mysql.sock

symbolic-links=0

log-bin=mysql-bin 启用二进制日志,用于记录数据库的更改操作

servid-id=1 设置mysql服务器的唯一id

进入数据库配置用户权限

mysql -pxxx

create user 'repl'@'%' identified by 'test'; 生成专门用来做复制的用户,用于slave端做认证

grant replication slave on *.* to 'repl'@'%' 对这个用户进行授权

配置slave

vim /etc/my.cnf

mysqld

datadir=/data/mysql

socket=/data/mysql/mysql.sock

symbolic-links=0

server-id=2

进入数据库进行配置

mysql -pxxx

change master to****master_host='172.25.254.11',master_user='repl',master_password='test',master_log_file='mysql-bin.000001',master_log_pos=xxx; 后面两个参数的具体数值可以通过在主数据库使用命令****show master status 来查看对应的参数的数值

start slave;

show slave status\G; 可以通过该命令查看主从服务器之间的状态

测试

create database xiao;

create table xiao.user(username varchar(20) not null,password varchar(50) not null)

在主数据库设备上创建测试的数据库

show databases; show tables 在从数据库的设备上查看相关的信息,看在主数据库创建的数据库和表是否同步到从数据库上

一般情况下在slave阶段中是开启写功能,但是一般会关闭slave节点的写功能来保证数据一致性。

vim /etc/mysql.cnf

mysqld

super_read_only=on 一般改为off

当有数据时添加slave2

vim /etc/my.cnf

mysqld

datadir=/data/mysql

socket=/data/mysql/mysql.sock

symbolic-links=0

server-id=3

mysqldump -uroot -pxxx test > xiao.sql 从master节点备份数据

在生产环境进行上述操作时备份时需要锁表,保证备份前后的数据一致性

mysql> flush tables with read lock;

备份后再解锁

unlock tables;

**拉平数据:**mysql -uroot -pxxx -e "create database xiao;"

mysql -uroot -pxxx >xiao.sql

mysql -uroot -pxxx -e "select * from xiao.user;"

配置slave2的slave功能,在此之前先在主数据库设备上查询最后需要对应的两个参数的值,然后利用同上的命令将slave2配置为master的从设备。

二、延迟复制

1.延迟复制是用来控制sql线程和io线程无关,其io线程正常工作,而是日志已经保存在slave端,而是sql要等多久进行回放

此种功能适用于当master端误操作时,可以在slave端进行数据备份

2.配置操作(该配置操作是在slave上进行配置的)

stop slave sql_thread;

change master to master_delay=60; 表示从服务器会延迟60s才执行主服务器上的更改

start slave sql_thread;

可以通过 show slave status\G来查看延迟的效果

三、慢查询日志

1.当执行sql超过long_query_time参数设定的时间阈值(默认为10s)时会被认为是慢查询,则这个慢查询是要被优化的

慢查询的日志会被记录在慢查询的日志中且默认情况下不开启慢查询

2.开启慢查询日志:

set global slow_query_log=ON;

set long_query_time=4;

show variables like "slow%"; 通过该命令可以查看慢查询日志是否开启

测试:

select sleep (10);

cat /data/mysql/mysql-node1-slow.log 该命令用来查看慢查询的日志信息

相关推荐
倔强的石头_2 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北1 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端