首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 主从定时备份

基础概念

MySQL主从复制是一种数据库复制技术,它允许一个MySQL数据库(主库)的数据被复制到一个或多个其他MySQL数据库(从库)。主从复制的目的是为了实现数据的冗余和高可用性,以及进行读写分离以提升性能。

相关优势

  1. 高可用性:当主库发生故障时,可以快速切换到从库,保证服务的连续性。
  2. 读写分离:主库负责写操作,从库负责读操作,可以分担服务器的负载。
  3. 数据备份:从库可以作为数据的备份,用于数据恢复。

类型

  1. 异步复制:主库在执行完写操作后立即返回,不等待从库确认。这是MySQL默认的复制方式。
  2. 半同步复制:主库在执行完写操作后,需要等待至少一个从库确认收到数据后才返回。
  3. 组复制:多个MySQL实例组成一个复制组,数据在组内同步。

应用场景

  1. 读写分离:将读操作和写操作分别分配到不同的服务器上,提升系统的整体性能。
  2. 数据备份:通过从库进行数据备份,保证数据的安全性。
  3. 高可用架构:当主库发生故障时,可以快速切换到从库,保证服务的连续性。

定时备份

定时备份可以通过编写脚本并使用操作系统的定时任务(如Linux的cron)来实现。以下是一个简单的示例脚本:

代码语言:txt
复制
#!/bin/bash

# 定义主库和从库的连接信息
MASTER_USER="backup_user"
MASTER_PASS="backup_password"
MASTER_HOST="master_host"
SLAVE_HOST="slave_host"

# 定义备份目录
BACKUP_DIR="/path/to/backup"

# 定义备份文件名
DATE=$(date +%Y%m%d%H%M%S)
BACKUP_FILE="$BACKUP_DIR/mysql_backup_$DATE.sql"

# 使用mysqldump进行备份
mysqldump -u$MASTER_USER -p$MASTER_PASS -h$SLAVE_HOST --single-transaction --master-data=2 $DATABASE > $BACKUP_FILE

# 压缩备份文件
gzip $BACKUP_FILE

# 删除7天前的备份文件
find $BACKUP_DIR -type f -name "mysql_backup_*.sql.gz" -mtime +7 -exec rm {} \;

遇到的问题及解决方法

  1. 备份失败
    • 原因:可能是由于网络问题、权限问题或mysqldump命令错误。
    • 解决方法:检查网络连接,确保主从库之间的网络通畅;检查备份用户的权限;确保mysqldump命令正确。
  • 备份文件过大
    • 原因:备份文件过大可能导致磁盘空间不足。
    • 解决方法:定期清理旧的备份文件;使用增量备份或分片备份。
  • 从库同步延迟
    • 原因:可能是由于从库负载过高或网络延迟。
    • 解决方法:优化从库的性能;增加从库的数量以分担负载;检查网络连接。

参考链接

通过以上信息,你应该能够了解MySQL主从定时备份的基础概念、优势、类型、应用场景以及常见问题及其解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • mysql定时备份任务

    简介 在生产环境上,为了避免数据的丢失,通常情况下都会定时的对数据库进行备份。而Linux的crontab指令则可以帮助我们实现对数据库定时进行备份。...,单纯的只是想要备份,那么上面那个命令就可以帮你进行定时备份。...如:晚上8点进行定时备份,但是却在晚上9点drop database,那么晚上8点到晚上9点这一个小时之内的数据却没有备份到。这时候就要使用binlog日志了。...晚上8点进行定时备份,但是却在晚上9点drop database,那么晚上8点到晚上9点这一个小时之内的数据却没有备份到。。...总结 因为mysql定时备份是在生产环境上必须的任务。是很常用的。所以我就迫不及待的写博客。当然也很感谢我同事的帮助。这篇文章已经写了三天了,因为我也是在不断地试错,不断的更新文章。

    1.9K20

    MySQL定时备份方案

    本片文章介绍的方案是利用Linux自身的crontab定时任务功能,定时执行备份数据库的脚本。...技术要点: 数据库备份dump命令 shell脚本 Linux定时任务crontab 数据备份dump 数据库都有一个导出数据库内数据和结构的命令,就是备份。...[导出.sql 文件] mysql: 备份 mysqldump -h -u [用户名] -p [库名] > [导出的.sql 文件] 恢复 mysql -u [用户名] -p [库名] < [导出的.../加脚本名称 chmod命令参数含义-- + 代表添加某些权限 x 代表可执行权限 定时任务crontab crontab是Linux自带的一个定时任务功能,我们可以利用它每天凌晨执行一次dump_mysql.sh...内容解释: 00 01 * * * /app/dump_mysql.sh 分两部分看, 第一部分00 01 * * * 是定时任务的周期,第二部分/app/dump_mysql.sh到时间做的事情。

    1.9K10

    Mysql主从备份和SQL语句的备份

    大家好,又见面了,我是全栈君 MySQL服务器的主从配置,本来是一件很简单的事情,无奈不是从零开始,总是在别人已经安装好的mysql服务器之上 ,这就会牵扯到,mysql的版本,启动文件,等一些问题。.../mysql-bin.log #确保此文件可写 read-only =0 #主机,读写都可以 binlog-do-db =test #需要备份数据,多个写多行 binlog-ignore-db...=mysql #不需要备份的数据库,多个写多行 3、打开从机B的my.cnf,输入 server-id = 2 log_bin = /var/...#需要 备份的数据库 binlog-do-db = hhy #不需 要备份的数据库 #binlog-ignore-db = ** 从服务器上设置 server-id=2 #(配置多个从服务器时依次设置...,如果备份多个数据库,重复设 置这个选项即可 重启主从 slave start; show slave status; Slave_IO_Running 和 Slave_SQL_Running 两列的值都为

    1.5K20

    mysql主从备份及原理分析

    一.mysql主从备份(复制)的基本原理 mysql支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。...从服务器执行备份不会干扰主服务器,在备份过程中主服务器可以继续处理更新。 二.mysql主从备份配置方法 在进行mysql主从备份时,最好确保主从服务器的版本兼容。...此时主服务器默认对所有数据库进行备份。如果需要特殊指明只对某个数据库进行备份或不备份,则可以加入binlog-do-db和binlog-ignore-db选项。...3.导出主服务器数据 导出主服务器数据,以备之后将其导入从服务器,使主从服务器的初始状态保持一致。...三.主从备份的实现细节 mysql使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上)。

    1.1K20

    linux mysql定时备份脚本记录

    备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程。...而对于一些网站、系统来说,数据库就是一切,所以做好数据库的备份是至关重要的! ---- 1. 创建备份 备份脚本: #!.../bin/bash date_str=$(date +%Y%m%d-%T) cd /bf/mysql_back mysqldump -h localhost -u root --password=PASSWORD... -R -E -e \databaseName \   | gzip > /bf/mysql_back/database_$date_str.sql.gz 2.执行定时任务 利用crontab定时执行上述脚本...crontab -e 每周一凌晨执行备份 05 02 * * 1 /home/mysqls_backup/mysqlbackup.sh 查看crontab列表 crontab -l 即时生效 /etc

    1.3K20

    Mysql数据库定时备份

    MySQL数据备份 mysqldump命令备份数据 在MySQL中提供了命令行导出数据库数据以及文件的一种方便的工具mysqldump,我们可以通过命令行直接实现数据库内容的导出dump,首先我们简单了解一下.../mydb.sql 还原mysql备份内容 有两种方式还原,第一种是在MySQL命令行中,第二种是使用SHELL行完成还原 在系统命令行中,输入如下实现还原: mysql -uroot -p123456...以下代码功能就是针对mysql进行备份,配合crontab,实现备份的内容为近一个月(31天)内的每天的mysql数据库记录。...编写备份脚本 在Linux中,使用vi或者vim编写脚本内容并命名为:mysql_dump_script.sh #!...定期执行编写的定时任务脚本(记得先给shell脚本执行权限) 每5分执行一次 ```bash */5 * * * * /data/cron/mysql_dump_script.sh 注意:这操作是直接替换该用户下的

    8.9K20

    Mysql数据库定时备份

    Mysql数据库定时备份 背景 首先我不是DBA,我只是个后端开发,有一个自己的网站,突然有一天,听到有个同学说,他们数据库被黑了,别人黑完删库跑路了,请教我怎么恢复,同学是非开发人员,其实我很想说我也不会...我快速百度了下怎么恢复,网上教我们的手段一般有: 数据库备份了么? 同学说没有,pass。 日志开启了么? 同学说没有,pass。 你数据库是MyIsam,看看黑客有没有把文件转移?...所以,我赶紧把我的mysql数据库备份了一下,用最简单的方式。 内容过于简单,可能会引起部分人群不适。...简单备份 mysqldump -u root -p feiyun > feiyun.sql.20190507 这里,feiyun 是数据库名,-u 是指定用户名, -p是输入密码 , -> 重定向到文件...定时备份 cron中添加一个作业 # crontab –e 0 1 * * * /root/dump/backup.sh 每天1点执行下backup.sh backup.sh: #!

    3.8K30

    MySQL主从备份和主主备份配置+Keepalived+MySQL读写分离

    一、MySQL主从备份 为保证数据库的安全和效率,可以使用主从备份,当有写的操作可以在主服务器上操作,操作完之后备份到从服务器上,当有读操作时可以访问从服务器,这样在一定程度上保证了数据库的安全,当主服务器的...主主备份 主主备份的设置就是将从服务器上的设置在主服务器上操作一遍,主服务器上的操作在从服务器上操作一遍,这里就不再赘述 三、 MySQL+Keepalived 环境: keepalived主机:192.168.174.129...服务,成功 也可以查出数据库 keepalived+mysql主从同步成功 四、MySQL读写分离 mysql读写分离是在mysql主从同步的基础上做的,mysql主服务器负责写,多台mysql从服务器负责读...,mysql主从同步仅仅是把mysql主服务器的数据库同步到了mysql从服务器上,如果要实现读写分离,还需要一个服务器去协调。...主从备份+mysql读写分离配置完成。

    3.3K30

    利用 Docker 快速实现 MySQL binlog 主从备份

    [Docker] Intro 主从备份是容灾的一种手段, 模拟主从备份可以有下面几种方式: 不差钱方式, 买几台主机测试, 这种方式也比较接近线上环境. 通过创建几台虚拟机来模拟....expire_logs_days=7 ## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。...配置主从 可以直接进入容器再进入 mysql 配置, 也可以不进入, 直接在终端键入下方命令, port 就是 docker-compose.xml 设置的端口号, 例如前面 master 的 33065...后话——另一种主从复制 GTID GTID 自 MySQL 5.6.MySQL 5.6.5 便引入了,中文叫全局事务 ID(Global Transaction ID) 在本文的基于二进制日志复制中,从库需要告知主库要从哪个偏移量...参考 Docker Compose搭建MySQL主从复制集群 GTID Concept - MySQL Docker 从入门到实践 - Compose 命令说明 --------------------

    1.5K00

    windows mysql 自动备份的几种方法(定时备份)

    1、复制date文件夹备份 ============================ 假想环境: MySQL   安装位置:C:\MySQL 论坛数据库名称为:bbs 数据库备份目的地:C:\db_bak...2、mysqldump备份成sql文件 ============== 假想环境: MySQL   安装位置:C:\MySQL 论坛数据库名称为:bbs MySQL root   密码:123456 数据库备份目的地...(日期的字符串的下标是从0开始的) 3、利用WinRAR对MySQL数据库进行定时备份。 对于MySQL的备份,最好的方法就是直接备份MySQL数据库的Data目录。...下面提供了一个利用WinRAR来对Data目录进行定时备份的方法。 首先当然要把WinRAR安装到计算机上。...这种方法缺点是占用时间比较多,备份期间压缩需要时间,mysql断开比第一种方法更多的时间,但是对于文件命名很好。

    6.6K30

    mysql 数据库 定时自动备份

    一、mysql提供了一个mysqldump的工具可以方便的导出导入数据库信息; 一般情况下mysql的数据库安装成功后,mysqldump的位置在:/usr/bin 的目录会有mysqldump这个文件...#mysql_bin_dir:mysql的bin路径; #dataname:数据库名; #user:数据库用户名; #password:用户密码; #name:自定义备份文件前缀标识 # name:自定义备份文件前缀标识...#数据库备份的位置 backupdir=/home/mysqlbak time=` date +%Y%m%d%H%M%S` #需要备份的数据库的连接的用户名和密码和数据库 #mysql_bin_dir/..._$time.sql.gz #传输至备份服务器,如果保留本机则不需要此步骤 #scp $backupdir/mysql_$time.sql.gz 22.122.51.158:/data/bakup/159...image.png 第三步:创建bakmysql.sh中的备份文件夹 ? image.png 第四步:配置linux定时任务 创建定时任务:crontab -e [图片上传失败...

    4.3K10

    java实现定时备份手动备份还原mysql数据库

    定时备份与还原 简介:配置一个时间监听器,通过util中的日期类和定时器控件解析相关的时间数据,在相应的时间调用备份数据库的方法....备份数据库的方法使用了mysql自带的mysqldump进行备份,得到数据库的sql文件,完成备份....下面是具体的实现 首先,相关配置文件,放在文件类路径下 (dbBackUpRecover.properties) #smysql备份功能路径与数据库用户名和密码 #//usr//bin 为mysql...startDT.add(Calendar.DAY_OF_MONTH, num); return startDT.getTime(); } } 时间监听器,用于启动定时备份数据库操作...因为做的项目中使用的是定时的备份,所以手动的备份只是测试了一下,并没有进行相关细节的完善,如果想使用本模块,对应定时备份的实现修改即可 具体实现类 import org.springframework.stereotype.Controller

    6.4K31
    领券