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');

复制代码
相关推荐
森叶5 分钟前
《深度拆解数据库连接池:从底层 TCP 原理到 PHP-FPM 与 Swoole/Go 的架构演进》
数据库·tcp/ip·php
Paxon Zhang7 分钟前
MySQL初阶入门的第一步
数据库·mysql·adb
littlegirll13 分钟前
一个KADB报错分析及实验
java·javascript·数据库
十年编程老舅20 分钟前
吃透 Linux 内核 IO 体系:块缓存与页缓存的核心设计与实现逻辑
linux·数据库·c++·spring·后端技术·页缓存
XDHCOM23 分钟前
PHP用来把Oracle的数据搬到Mysql里边的一个具体操作示范过程
mysql·oracle·php
数据知道27 分钟前
MongoDB批量操作优化:bulkWrite提升写入性能的实战方法
数据库·mongodb
无风听海28 分钟前
LangGraph 控制流原语解析:Edge、Command、Send、Interrupt
java·数据库·edge
数据知道32 分钟前
MongoDB读写关注设置:如何平衡数据一致性与系统性能?
数据库·mongodb
数据知道38 分钟前
MongoDB大数据量分页优化:避免skip()性能陷阱的替代方案
网络·数据库·mongodb
2401_883035461 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python