MySQL主从复制

文章目录

1.主从复制

1.1 概念和原理

1.2 案例:一主一从

1)准备工作
  • 同步时间
shell 复制代码
# 安装 ntpdate
yum -y install ntpdate
# 同步时间
ntpdate pool.ntp.org
# 阿里云同步时间
ntpdate ntp1.aliyun.com
  • 如果是克隆的虚拟机,则需要修改 mysql 的 uuid
    mysql5.6以上版本使用唯一uuid表示符,数据迁移是使用的物理备份,uuid会重复,修改uuid不一致即可
    修改过后,重启 mysql 服务
2)master
shell 复制代码
# 编辑 mysql 配置文件
vim /etc/my.cnf

# 写入以下内容
server-id=1
read-only=0
log-bin=mysql-bin
#binlog-do-db=my_test

# 重启服务
systemctl restart mysqld.service
shell 复制代码
# 登录 mysql
mysql -uroot -p

# 创建用户,并授予主从复制权限
mysql> create user 'my'@'%' identified with mysql_native_password by 'Bdqn_8888';
mysql> grant replication slave on *.* to 'my'@'%';

# 查看主机上的binlog信息,如下图
mysql> show master status;
3)slave
shell 复制代码
# 编辑 mysql 配置文件
vim /etc/my.cnf

# 写入以下内容
server-id=2
read-only=1
log-bin=mysql-bin

# 重启服务
systemctl restart mysqld.service
shell 复制代码
# 登录 mysql
mysql -uroot -p

# 在从机上设置主机相关信息
mysql> CHANGE MASTER TO
master_host='192.168.9.3',
master_user='my',
master_password='Bdqn_8888',
master_port=3306,
master_log_file='mysql-bin.000001',
master_log_pos=154;


#需要注意要与主机的 File 名一模一样
#master_log_file='mysql-bin.000001',
#需要注意要与主机的 Position 位置一模一样  
#master_log_pos=348;


# 开启从机
mysql> START SLAVE;

# 查看状态,如下图
mysql> SHOW SLAVE STATUS\G;
4)测试
shell 复制代码
# 登录mysql主机
mysql -uroot -p

# 建库建表添加数据
mysql> create database mytext;

mysql> use mytext;

mysql> create table stu(
  id int(10) primary key not null auto_increment,
  name varchar(50) not null,
  gender char(1) not null
)engine=innodb default charset=utf8mb4;

mysql> insert into stu values (null,'tom','m'),(null,'jack','m'),(null,'marry','f');

ar(1) not null

)engine=innodb default charset=utf8mb4;

mysql> insert into stu values (null,'tom','m'),(null,'jack','m'),(null,'marry','f');

复制代码
相关推荐
微学AI7 分钟前
树莓派搭建便携弱网测试网关:基于 Facebook ATC 的实践指南
数据库·内网穿透
小江的记录本8 分钟前
【Bean】JavaBean(原生规范)/ Spring Bean 【重点】/ 企业级Bean(EJB/Jakarta Bean)
java·数据库·spring boot·后端·spring·spring cloud·mybatis
m0_6625779710 分钟前
自动化与脚本
jvm·数据库·python
讯方洋哥13 分钟前
HarmonyOS App开发——鸿蒙ArkTS端云一体化云数据库应用和实战
数据库·harmonyos
闻哥14 分钟前
MySQL InnoDB 缓存池(Buffer Pool)详解:原理、结构与链表管理
java·数据结构·数据库·mysql·链表·缓存·面试
heze0916 分钟前
sqli-labs-Less-50
数据库·mysql·网络安全
gechunlian8822 分钟前
redis exporter手册
数据库·redis·缓存
木易 士心34 分钟前
深入理解 MySQL 权限撤销(REVOKE)机制:从语法到安全实践
数据库·后端·mysql·安全
小龙报1 小时前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
dapeng28701 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python