SQL 主从数据库实时备份

在SQL数据库中,主从复制(Master-Slave Replication)是一种常见的实时备份和高可用性解决方案。这种配置允许将一个数据库服务器(主服务器)的更改同步到一个或多个其他数据库服务器(从服务器),从而实现数据的实时备份和可用性提高。以下是一般步骤,用于在SQL数据库中设置主从复制:

  1. 配置主服务器:

-确保主服务器上已启用二进制日志(binary logging),这是记录对数据库的更改的一种机制。

-配置主服务器的`my.cnf`(或其他配置文件)以启用二进制日志和设置唯一的服务器ID。

ini

server_id = 1

log_bin = /var/log/mysql/mysql-bin.log

重启主服务器以应用配置。

  1. 创建用于复制的用户:

在主服务器上创建一个用于从服务器连接的用户,并为该用户分配复制权限。

sql

CREATE USER 'replication_user'@'%' IDENTIFIED BY 'password';

GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%';

FLUSH PRIVILEGES;

  1. 获取主服务器的当前状态:
  • 在主服务器上运行以下命令,以获取主服务器的当前状态:

sql

SHOW MASTER STATUS;

记下输出中的文件名(File)和位置(Position),这将在配置从服务器时用到。

  1. 配置从服务器:

在从服务器上编辑`my.cnf`文件,配置从服务器的唯一服务器ID。

ini

server_id = 2

  • 重启从服务器以应用配置。
  1. 开始复制:

在从服务器上运行以下命令,以开始从主服务器复制数据:

sql

CHANGE MASTER TO

MASTER_HOST='master_ip',

MASTER_USER='replication_user',

MASTER_PASSWORD='password',

MASTER_LOG_FILE='master_log_file_from_master_status',

MASTER_LOG_POS=master_log_pos_from_master_status;

START SLAVE;

替换上述命令中的参数为主服务器的IP地址、创建的复制用户的用户名和密码以及从`SHOW MASTER STATUS;`获得的文件名和位置。

  1. 检查复制状态:

在从服务器上运行以下命令,以检查复制状态:

sql

SHOW SLAVE STATUS\G;

确保输出中的`Slave_IO_Running`和`Slave_SQL_Running`都显示为`Yes`,表示复制正在运行。

一旦配置完成,主从复制就建立起来了,主服务器上的更改将自动同步到从服务器上。这提供了实时备份和在主服务器故障时切换到从服务器的可能性,从而提高了系统的可用性。

相关推荐
dFObBIMmai18 分钟前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw021 分钟前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl2002092538 分钟前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
ACP广源盛139246256731 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Elastic 中国社区官方博客1 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
俺不要写代码2 小时前
数据库:函数
数据库·mysql
2401_882273722 小时前
如何在 CSS 中正确加载本地 JPG 背景图片
jvm·数据库·python
曹牧2 小时前
SQL:多个事务同时修改同一索引块
数据库·sql
aXin_ya2 小时前
微服务第八天 Sentinel 四种分布式事务模式
java·数据库·微服务
Ruci ALYS3 小时前
MySQL大小写敏感、MySQL设置字段大小写敏感
数据库·mysql