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

复制代码
相关推荐
恣艺1 小时前
Redis列表(List):实现队列/栈的利器,底层原理与实战
数据库·redis·list
秋难降2 小时前
零基础学习SQL(十一):SQL 索引结构|从 B+Tree 到 Hash,面试常问的 “为啥选 B+Tree” 有答案了
数据库·后端·mysql
代码的余温2 小时前
Linux内核调优实战指南
linux·服务器·数据库
almighty272 小时前
C# DataGridView表头自定义设置全攻略
数据库·c#·winform·datagridview·自定义表头
ljh5746491193 小时前
mysql 必须在逗号分隔字符串和JSON字段之间二选一,怎么选
数据库·mysql·json
论迹3 小时前
【Redis】-- 持久化
数据库·redis·缓存
getdu3 小时前
Redis面试相关
数据库·redis·面试
TDengine (老段)3 小时前
TDengine 选择函数 TOP() 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
m0_694845573 小时前
教你使用服务器如何搭建数据库
linux·运维·服务器·数据库·云计算
gamers4 小时前
rock linux 9 安装mysql 5.7.44
linux·mysql·adb