centos实现mysql定时备份(单机)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: centos实现mysql定时备份(单机)

centos实现mysql定时备份(单机)

创建备份脚本:

首先,我们需要创建一个 Shell 脚本来执行 MySQL 数据库的备份操作。我们可以将备份脚本命名为 backup_mysql.sh。以下是 backup_mysql.sh 的内容:

#!/bin/bash
# 数据库连接信息
DB_HOST="localhost"
DB_USER="root"
DB_PASS="123456"
DB_NAME="ceshi"
DB_PORT="3341"
# 备份目录
BACKUP_DIR="/home/mysql/back"
# 备份文件名,包含日期和时间
BACKUP_FILE="${BACKUP_DIR}/backup_$(date +'%Y%m%d_%H%M%S').sql"
# mysqldump 命令,备份数据库到指定文件
/usr/bin/mysqldump --opt --single-transaction --default-character-set=utf8 --skip-extended-insert -h $DB_HOST -P $DB_PORT -u $DB_USER -p$DB_PASS $DB_NAME > $BACKUP_FILE
# 删除过期备份文件,只保留最近 30 天的备份
find $BACKUP_DIR -type f -name "backup_*.sql" -mtime +30 -exec rm {} \;

参数说明

说明一下上面的参数

  • 如果你的mysql端口是3306,那么就可以不指定端口,因为默认就是3306,这里之所以这么写为了安全
  • 使用whereis mysqldump来获取你的mysqldump,一般是在/usr/bin/mysqldump
  • --opt:如果有这个参数表示同时激活了mysqldump命令的quick,add-drop-table,add-locks,extended-insert,lock-tables参数,它可以给出很快的转储操作并产生一个可以很快装入MySQL服务器的转储文件。当备份大表时,这个参数可以防止占用过多内存
  • --single-transaction 设置事务的隔离级别为可重复读,然后备份的时候开启事务,这样能保证在一个事务中所有相同的查询读取到同样的数据。注意,这个参数只对支持事务的引擎有效,如果有 MyISAM 的数据表,并不能保证数据一致性
  • 这里如果你导出的不是上面的表,而是全表可以替换为参数-A
  • --skip-extended-insert 默认情况下,mysqldump 命令在导出 SQL 文件时会将多个 INSERT 语句合并成一批进行导出,以提高导入性能。如果你希望将每个 INSERT 语句单独导出,即一条一条导出,可以使用 --skip-extended-insert 参数来实现。使用 --skip-extended-insert 参数后,mysqldump 会将每个 INSERT 语句单独导出,而不会合并为一批。这样导出的 SQL 文件会比较大,但可以确保每条数据都以单独的 INSERT 语句形式保存,方便阅读和处理。

对于上面的- --skip-extended-insert如果没加的话,导出的sql文件是相对较小的,但是如果某一个表中的数据过大,在Navicat中导入就会报错ERR] 2006 - Server has gone away,解决办法就是如将wait_timeoutmax_allowed_packet设置大一点

定时任务实现

  • 确定脚本位于什么位置下:到达脚本位置,执行pwd命令
  • 执行以下命令
crontab -e
  • 编写定时任务命令
0 0 * * * /bin/bash /path/to/backup_mysql.sh

这将在每天的 00:00 执行我们之前创建的 backup_mysql.sh 脚本,并实现自动备份数据库。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
安全 关系型数据库 MySQL
解决centos7.0安装mysql后出现access defind for user@'localhost'的错误
在使用yum 安装完mariadb, mariadb-server, mariadb-devel后
8 0
|
5天前
|
Prometheus Cloud Native 关系型数据库
实时计算 Flink版产品使用合集之binlog被清理掉的问题,并且binlog有备份,有什么方法来恢复到RDS
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
22 2
|
7天前
|
关系型数据库 MySQL Linux
服务器Linux系统配置mysql数据库主从自动备份
这是一个基本的配置主从复制和设置自动备份的指南。具体的配置细节和命令可能因您的环境和需求而有所不同,因此建议在操作前详细阅读MySQL文档和相关资源,并谨慎操作以避免数据丢失或不一致。
23 3
|
7天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
45 0
|
7天前
|
关系型数据库 MySQL Linux
本地虚拟机centos7通过docker安装主从mysql5.7.21
本地虚拟机centos7通过docker安装主从mysql5.7.21
29 0
|
7天前
|
关系型数据库 MySQL Linux
在Centos7中:通过Docker安装MySQL5.7(保姆级)
在Centos7中:通过Docker安装MySQL5.7(保姆级)
149 0
|
7天前
|
前端开发 jenkins 持续交付
新的centos7.9安装docker版本的jenkins2.436.1最新版本-前端项目发布(五)
新的centos7.9安装docker版本的jenkins2.436.1最新版本-前端项目发布(五)
31 1
|
7天前
|
jenkins 网络安全 持续交付
新的centos7.9安装docker版本的jenkins2.436.1最新版本-后端项目发布(四)
新的centos7.9安装docker版本的jenkins2.436.1最新版本-后端项目发布(四)
33 3
|
1天前
|
网络协议 Java Linux
CentOS上安装运行XWiKi
CentOS上安装运行XWiKi
7 0
|
1天前
|
Java Linux
CentOS上安装openjdk
CentOS上安装openjdk
8 0

热门文章

最新文章