百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL 主从数据库配置(mysql主从原理怎么配置文件)

wptr33 2025-03-13 21:06 15 浏览

最近在做主从数据库,数据备份,还有读写分离,将操作过程记录一下

一、环境准备

  1. 服务器信息
  2. 主库(Master):IP 192.168.1.100,MySQL 版本 ≥5.6
  3. 从库(Slave):IP 192.168.1.101,MySQL 版本与主库一致
  4. 网络要求
  5. 主从服务器间可互相访问(默认端口 3306 开放)。
  6. 确保主从库的 server-id 唯一。

二、主库(Master)配置

1.修改主库配置文件

编辑 MySQL 配置文件 my.cnf(路径通常为 /etc/my.cnf 或
/etc/mysql/mysql.conf.d/mysqld.cnf):

ini

复制

[mysqld]
# 主库唯一标识(必须唯一)
server-id = 1
# 开启二进制日志(核心配置)
log-bin = mysql-bin
# 二进制日志格式(建议使用ROW格式)
binlog_format = ROW
# 可选:指定需要复制的数据库(不配置则默认同步所有库)
# binlog_do_db = db1
# binlog_do_db = db2

重启 MySQL 服务:

bash

复制

systemctl restart mysqld

2.创建复制账号

登录主库 MySQL,创建用于复制的账号并授权:

sql

复制

-- 创建用户(用户名 repl,密码 repl_password)
CREATE USER 'repl'@'%' IDENTIFIED BY 'repl_password';
-- 授予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
FLUSH PRIVILEGES;

3.获取主库当前 Binlog 状态

执行以下命令,记录 File 和 Position 的值(从库配置时需要):

sql

复制

SHOW MASTER STATUS;

输出示例:

复制

+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 | 154      |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+

三、从库(Slave)配置

1.修改从库配置文件

编辑从库的 my.cnf:

ini

复制

[mysqld]
server-id = 2        # 唯一标识,不能与主库相同
relay-log = mysql-relay-bin  # 中继日志名称
read-only = 1         # 从库只读(可选,根据业务需求)

重启 MySQL 服务:

bash

复制

systemctl restart mysqld

2.配置主库连接信息

登录从库 MySQL,执行以下命令指定主库信息:

sql

复制

CHANGE MASTER TO
  MASTER_HOST = '192.168.1.100',  -- 主库 IP
  MASTER_USER = 'repl',           -- 主库复制账号
  MASTER_PASSWORD = 'repl_password',
  MASTER_PORT = 3306,             -- 主库端口
  MASTER_LOG_FILE = 'mysql-bin.000001',  -- 主库的 Binlog 文件名
  MASTER_LOG_POS = 154;           -- 主库的 Binlog 位置

3.启动复制线程

sql

复制

START SLAVE;

四、数据同步(若主库已有数据)

如果主库已有数据,需先将主库数据完整备份并导入从库:

1.主库备份数据

使用 mysqldump 备份数据(注意记录备份时的 Binlog 位置):

bash

复制

# 备份所有数据库(推荐锁表保证一致性)
mysqldump -u root -p --all-databases --master-data=2 > master_dump.sql
  • --master-data=2:在备份文件中记录主库的 File 和 Position。

2.导入数据到从库

将备份文件传输到从库服务器,并导入:

bash

复制

mysql -u root -p < master_dump.sql

3.重新配置从库

如果备份文件中已包含 File 和 Position,可直接使用备份文件中的值:

sql

复制

STOP SLAVE;
CHANGE MASTER TO ...;  -- 使用备份文件中的 MASTER_LOG_FILE 和 MASTER_LOG_POS
START SLAVE;

五、验证主从复制

1.检查从库复制状态

在从库执行:

sql

复制

SHOW SLAVE STATUS\G;

关注以下字段:

  • Slave_IO_Running:必须为 Yes(表示 I/O 线程正常)。
  • Slave_SQL_Running:必须为 Yes(表示 SQL 线程正常)。
  • Seconds_Behind_Master:表示复制延迟(0 表示无延迟)。
  • Last_IO_Error/Last_SQL_Error:错误信息(如有问题需排查)。

2.测试数据同步

  • 在主库执行写入操作(如建表、插入数据):
  • sql
  • 复制
  • CREATE DATABASE test_db; USE test_db; CREATE TABLE test_table (id INT); INSERT INTO test_table VALUES (1);
  • 在从库查询是否同步成功:
  • sql
  • 复制
  • SELECT * FROM test_db.test_table;

六、常见问题处理

  1. Slave_IO_Running 为 No
  2. 检查主从网络连通性(telnet 主库IP 3306)。
  3. 验证复制账号权限和密码是否正确。
  4. 检查主库的 bind-address 是否允许从库连接。
  5. Slave_SQL_Running 为 No
  6. 查看 Last_SQL_Error 字段定位错误。
  7. 常见原因:主从数据不一致(如从库被手动写入数据)。
  8. 解决方法:重新同步数据或跳过错误(谨慎操作):
  9. sql
  10. 复制
  11. STOP SLAVE; SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; -- 跳过1个错误 START SLAVE;

相关推荐

每天一个编程技巧!掌握这7个神技,代码效率飙升200%

“同事6点下班,你却为改BUG加班到凌晨?不是你不努力,而是没掌握‘偷懒’的艺术!本文揭秘谷歌工程师私藏的7个编程神技,每天1分钟,让你的代码从‘能用’变‘逆天’。文末附《Python高效代码模板》,...

Git重置到某个历史节点(Sourcetree工具)

前言Sourcetree回滚提交和重置当前分支到此次提交的区别?回滚提交是指将改动的代码提交到本地仓库,但未推送到远端仓库的时候。...

git工作区、暂存区、本地仓库、远程仓库的区别和联系

很多程序员天天写代码,提交代码,拉取代码,对git操作非常熟练,但是对git的原理并不甚了解,借助豆包AI,写个文章总结一下。Git的四个核心区域(工作区、暂存区、本地仓库、远程仓库)是版本控制的核...

解锁人生新剧本的密钥:学会让往事退场

开篇:敦煌莫高窟的千年启示在莫高窟321窟的《降魔变》壁画前,讲解员指着斑驳色彩说:"画师刻意保留了历代修补痕迹,因为真正的传承不是定格,而是流动。"就像我们的人生剧本,精彩章节永远...

Reset local repository branch to be just like remote repository HEAD

技术背景在使用Git进行版本控制时,有时会遇到本地分支与远程分支不一致的情况。可能是因为误操作、多人协作时远程分支被更新等原因。这时就需要将本地分支重置为与远程分支的...

Git恢复至之前版本(git恢复到pull之前的版本)

让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)方法一:gitreset...

如何将文件重置或回退到特定版本(怎么让文件回到初始状态)

技术背景在使用Git进行版本控制时,经常会遇到需要将文件回退到特定版本的情况。可能是因为当前版本出现了错误,或者想要恢复到之前某个稳定的版本。Git提供了多种方式来实现这一需求。...

git如何正确回滚代码(git命令回滚代码)

方法一,删除远程分支再提交①首先两步保证当前工作区是干净的,并且和远程分支代码一致$gitcocurrentBranch$gitpullorigincurrentBranch$gi...

[git]撤销的相关命令:reset、revert、checkout

基本概念如果不清晰上面的四个概念,请查看廖老师的git教程这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改存起来。后来用多了,也就明白了为什么。gi...

利用shell脚本将Mysql错误日志保存到数据库中

说明:利用shell脚本将MYSQL的错误日志提取并保存到数据库中步骤:1)创建数据库,创建表CreatedatabaseMysqlCenter;UseMysqlCenter;CREATET...

MySQL 9.3 引入增强的JavaScript支持

MySQL,这一广泛采用的开源关系型数据库管理系统(RDBMS),发布了其9.x系列的第三个更新版本——9.3版,带来了多项新功能。...

python 连接 mysql 数据库(python连接MySQL数据库案例)

用PyMySQL包来连接Python和MySQL。在使用前需要先通过pip来安装PyMySQL包:在windows系统中打开cmd,输入pipinstallPyMySQL ...

mysql导入导出命令(mysql 导入命令)

mysql导入导出命令mysqldump命令的输入是在bin目录下.1.导出整个数据库  mysqldump-u用户名-p数据库名>导出的文件名  mysqldump-uw...

MySQL-SQL介绍(mysql sqlyog)

介绍结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同...

MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南

在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...