MySQL主从环境搭建

MySQL主从环境搭建

主机MySQL配置

  1. 修改主机配置文件
java 复制代码
vim /etc/my.cnf

主要是在my.cnf配置文件中增加以下内容:

java 复制代码
#主服务器唯一ID
server-id=1
#启用二进制日志
log-bin=mysql-bin
# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
#设置需要复制的数据库
binlog-do-db=TESTDB
#设置logbin格式
binlog_format=STATEMENT
  1. 创建用于从机复制时连接主机的账号以及设置权限
    这里创建的账号后面从机连接时会用到

在主机中打开mysql命令行,执行下面的命令,创建从机连接主机的账号以及设置权限。

slave是用户名称;192.168.200.225是登录域名,这里是从机的ip;123123是登录密码

java 复制代码
create user 'slave'@'192.168.200.225' identified by '123123'; 

设置权限,这里给了这个账号所有的权限。

java 复制代码
grant all privileges on *.* to 'slave'@'192.168.200.225' with grant option; 

通过下面的命令查看账号拥有的权限

java 复制代码
show grants for 'slave'@'192.168.200.225';
  1. 查看主机的状态
java 复制代码
 show master status;

这里的File和Position字段的值等下从机连接主机时需要用到。 需要注意的是,重启MySQL服务后这两个值可能会发生变化。

从机MySQL配置

  1. 在从机的my.cnf配置文件中加入以下内容
java 复制代码
#从服务器唯一ID
server-id=2
#启用中继日志
relay-log=mysql-relay

需要注意的是,修改配置文件后重启才会生效。

  1. 在从机上配置主机

MASTER_HOST是主机的ip;MASTER_LOG_FILE是前面使用show master status展示出来的值,MASTER_LOG_POS也是一样的。

java 复制代码
CHANGE MASTER TO MASTER_HOST='192.168.200.215',
MASTER_USER='slave',
MASTER_PASSWORD='123123',
MASTER_LOG_FILE='mysql-bin.000013',MASTER_LOG_POS=120;
  1. 启动从机
java 复制代码
#启动从机
start slave;

#停止从机
stop slave;
  1. 查看从机的状态
java 复制代码
 show slave status\G;

当下图中的Slave_IO_Running和Slave_SQL_Running都是Yes就说明主从配置成功。

我这里Slave_IO_Running一开始是Connecting状态,原因在于主机中创建的slave账号权限没有给。其它可能的原因是主机和从机的防火墙开着,所以连接不上;或者端口未开放。详细信息可以查看错误日志。

测试主从配置

在主机中创建TESTDB数据库,然后创建user表,插入一条记录;然后刷新从机的数据库,就可以看到从机同步了TESTDB数据以及表中的记录。

主机

从机

可以看到从机同步了主机的数据。

参考

  1. mysql8.0数据库添加用户和授权
  2. linux服务器上查看mysql日志文件位置
  3. mysql 8.0 + Last_IO_Error: error connecting to master 'root@XXX:3306' - retry ...
  4. MySQL 8.0主从(Master-Slave)配置
相关推荐
恋猫de小郭12 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
恋猫de小郭12 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
贾艺驰15 小时前
实战Android Framework: 新增一个系统权限
android
alexhilton20 小时前
使用Android Archive进行打包
android·kotlin·android jetpack
badhope21 小时前
做了几年安卓开发,这些坑我帮你踩过了
android·android studio
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二3 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
逐光老顽童3 天前
Java 与 Kotlin 混合开发避坑指南:30 个真实案例实录
android·kotlin
冬奇Lab3 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm