linux环境用mysqldump定时备份Mysql数据

yumo6664个月前 (03-29)技术文章34

一、Mysql备份脚本backup.sh

vi backup.sh

#!/bin/bash
# 保存备份个,备份31天的数据
number=31
# 备份保存路径
backup_dir=/home/mysql/data/mysqlbackup
# 日期
dd=`data+%Y-%m-%d-%H-%M-%S`
# 备份工具
tool=mysqldump
# 用户名
username=name
# 密码,特殊字符要转化
password=pwd
# 要备份的数据库
database_name=数据库名
# 如果文件夹不存在则创建
if [.! -d $backup_dir ];
then
 mkdir -p $backup_dir;
fi
$tool -u $username -p$password $database_name >$backup_dir/$dataabase_name-$dd.sql
# 写创建备份日志
echo "create $backup_dir/$database_name-$dd.dupm" >>$backup_dir/log.txt
# 找出需要删除的备份
delfile=`ls -l -crt $backup_dir/*.sql | awk '{print $9}' |head -l`
# 判断现在的备份数量是否大雨$number
count=`ls -l -crt $backup_dir/*sql | awk '{print}' | wc -l`
if [.$count -gt $number ]
then
 # 删除最早生成的备份,只保留number数量的备份
 rm $delfile
 # 写删除文件日志
 echo "delete $delfile" >> $backup_dir/log.txt
fi

二、linux的crontab调度

crontab -e
0 5 * * * /root/bin/backup.sh

上述设定表示,每日5点运行该脚本。

crontab的解释:

第一列表示分钟

第二列表示小时

第三列表示日期

第四列表示月份

第五列表示星期

第六列表示运行的脚本或者命令

三、mysqldump

1、简介

mysqldump -u 'user' -p 'password' database1 > database1.sql

-u:连接mysql的用户

-p:连接mysql服务的账户密码

database1:mysqldump的第一个参数为数据库名称

2、备份多个库

mysqldump -u 'user' -p 'password' database1 database2 > database1_ database2.sql

3、备份某张表

mysqldump -u 'user' -p 'password' database1 table1 > database1_table1.sql

4、备份多张表

mysqldump -u 'user' -p 'password' database1 table1 table2 > database1_table1_table2.sql

5、远程备份

mysqldump -h'127.0.0.1' -u 'user' -p 'password' database1 > database1.sql

相关文章

解放你的双手,ubuntu定时自动备份MySQL数据库,亲测有效

1、新建一个文件夹存放备份的数据文件,根据个人需要放在合适的位置mkdir /home/cms_mysqlbackup 2、创建脚本文件,我放在home文件夹了,命名为autobackup.shcd...

MySQL数据库备份

前端监控:www.webfunny.cn ;只需要简单几步,就可以搭建一套属于自己的前端监控系统,快来试试吧。(github:webfunny_monitor)一、mysqldump 简介mysqld...

使用docker备份mysql数据库

数据在项目中绝对是非常重要的,若数据发生丢失,很容易造成难以挽回的损失。所以,数据库备份在生产上是必不可少的,下面我们来了解下在docker环境下mysql数据库的备份是如何做的。一、数据库容器假设我...

mysql自动备份,并zabbix检测备份文件是否正常,备份文件大小

推荐mongodb自动备份,并zabbix检测备份文件是否正常CentOS 7.9服务器,一分钟部署完mysql8.0Ubuntu22部署MySQL8.0二进制安装快速部署mysql主从,zabbix...

MySQL无需API开发连接维格表,实现订单数据自动汇总到表单

MySQL用户使用场景:电商商家会将所有的订单信息存储到MySQL数据库中,同时还需同步到维格表进行汇总,便于企业人员查询及负责人查看某一时间段的数据,但一张订单常包含流水号、车号、货品名称,发/收货...