MySQL 备份

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: 原文:MySQL 备份 http://rimuhosting.com/howto/mysqlbackup.jsp  Automated MySQL Database BackupVersion 1 Want to backup your MySQL databases to a...
原文: MySQL 备份

http://rimuhosting.com/howto/mysqlbackup.jsp

 

Automated MySQL Database Backup

Version 1

Want to backup your MySQL databases to another machine on a nightly basis? 

Then create a /etc/cron.daily/mysqlbackup.sh job like this:

mysqldump  -- compress  - u root  - p $pw   - $currenthost   -- add - drop - table  -- extended - insert  -- quote - names  -- databases db1 db2 |  mysql  - u root  - p $pw   - $remotehost

 

Run chmod +x /etc/cron.daily/mysqlbackup.sh.  And change the $ parameters to the appropriate 'real' values.

Or if you are not backing up to a separate host, run:

mysqldump  - u root  - p $pw   - $currenthost   -- add - drop - table  -- extended - insert  -- quote - names  -- databases db1 db2  >   / var / log / mysql . backup . $(date  + " %Y%m%d " ) . sql 

 

Version 2

This one is slightly more advanced. It's a bash script that will basically do the same as above but also only keep a certain number of old copies.

Note that this script is prepared to backup as the root user, if you are going to be running this as a non root user you should modify paths to reflect that.

# !/bin/sh

# List of databases to be backed up separated by space

dblist = " db_name_1 db_name_2 db_name_3 etc. "

#  Directory for backups
backupdir =/ root / mysql_dumps

#  Number of versions to keep
numversions = 4

#  Full path for MySQL hotcopy command
# Please put credentials into /root/.my.cnf
#hotcopycmd=/usr/bin/mysqlhotcopy

hotcopycmd = " /usr/bin/mysqldump --lock-tables --databases "

#  Create directory if needed
mkdir   - " $backupdir "
if  [  !   - " $backupdir "  ]; then
   echo 
" Invalid directory: $backupdir "
   
exit   1
fi

#  Hotcopy begins here
echo  " Dumping MySQL Databases... "
RC
= 0
for  database in  $dblist do
   echo
   echo 
" Dumping $database ... "
   mv 
" $backupdir/$database.gz "   " $backupdir/$database.0.gz "   2 >   / dev / null
   
$hotcopycmd   $database   |  gzip  >   " $backupdir/$database.gz "

   RC
= $ ?
   
if  [  $RC   - gt  0  ]; then
     
continue ;
   fi

   
#  Rollover the backup directories
   rm  - fr  " $backupdir/$database.$numversions.gz "   2 >   / dev / null
   i
= $numversions
   
while  [  $i   - gt  0  ];  do
     mv 
" $backupdir/$database.`expr $i - 1`.gz "   " $backupdir/$database.$i.gz "   2 >   / dev / null
     i
= `expr  $i   -   1 `
   done
done

if  [  $RC   - gt  0  ]; then
   echo 
" MySQL Dump failed! "
   
exit   $RC
else
   
#  Hotcopy is complete. List the backup versions!
   ls  - " $backupdir "
   echo 
" MySQL Dump is complete! "
fi
exit   0

 

So this system has three parts. First is the file that holds the credentials, e.g. /root/.my.cnf and it's in standard mysql config format like so:

#  cat /root/.my.cnf  [client] user=root password=whatever 

 

Second is the script itself, as listed above. Enter the names of your dbs, how many copies to keep, and where to put them.

 

Third is the crontab entry that will run this script for you. For example, once per day:

#  (Use to post in the top of your crontab)
# ----------------- minute (0 - 59)
# |  -------------- hour (0 - 23)
# |  |  ----------- day of month (1 - 31)
# |  |  |  -------- month (1 - 12)
# |  |  |  |  ----- day of week (0 - 7) (Sunday=0 or 7)
# |  |  |  |  |
# *  *  *  *  *  command to be executed


35   01   *   *   *   / root / mysql_backup . sh

 

 

完!

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
关系型数据库 MySQL Shell
shell学习(十七) 【mysql脚本备份】
shell学习(十七) 【mysql脚本备份】
27 0
|
2月前
|
关系型数据库 MySQL Linux
linux下mysql定时备份
linux下mysql定时备份
49 0
|
2月前
|
关系型数据库 MySQL Linux
mysql 主从同步 实现增量备份
mysql 主从同步 实现增量备份
33 0
|
2月前
|
关系型数据库 MySQL Linux
Linux系统使用定时脚本备份mysql
Linux系统使用定时脚本备份mysql
|
24天前
|
存储 SQL 关系型数据库
|
2月前
|
关系型数据库 MySQL Shell
备份 MySQL 的 shell 脚本(mysqldump版本)
【4月更文挑战第28天】
34 0
|
17天前
|
SQL 关系型数据库 MySQL
Navicate,数据库,Mysql,改表,4月29日Finished - Unsuccessfully,导出数据不妨,右键,备份一下Mysql数据库的内容,你想导入和导出数据不如,用查询的方式去做
Navicate,数据库,Mysql,改表,4月29日Finished - Unsuccessfully,导出数据不妨,右键,备份一下Mysql数据库的内容,你想导入和导出数据不如,用查询的方式去做
|
26天前
|
SQL 关系型数据库 MySQL
MySQL进阶 - 备份与恢复
MySQL进阶 - 备份与恢复
16 0
|
2月前
|
Prometheus Cloud Native 关系型数据库
实时计算 Flink版产品使用合集之binlog被清理掉的问题,并且binlog有备份,有什么方法来恢复到RDS
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
2月前
|
关系型数据库 MySQL Linux
服务器Linux系统配置mysql数据库主从自动备份
这是一个基本的配置主从复制和设置自动备份的指南。具体的配置细节和命令可能因您的环境和需求而有所不同,因此建议在操作前详细阅读MySQL文档和相关资源,并谨慎操作以避免数据丢失或不一致。
82 3