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

yumo6667个月前 (03-29)技术文章71

一、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

相关文章

MySQL管理授权和数据库的备份和还原详解

一般管理用户和授权由DBA去执行,DBA为数据库管理员一、管理用户1.添加用户CREATE USER '用户名'@'主机名'IDENTIFIED BY'密码';2.删除用户DROP USER '用户名...

数据库备份软件--Iperius Backup

这款软件可以实现:驱动器映像,备份到NAS,云,FTP,Dropbox,OneDrive,Google Drive,S3 VMware ESXi, vCenter, ESXi Free, Hyper-...

MySQL 8.0 备份选什么工具速度最快

备份分类MySQL的数据库备份可以分为两类:逻辑备份:把数据备份成MySQL可以解析的格式(例如:SQL语句或者文本文件。)其优势:如果MySQL数据文件损坏,内存中的数据还是正确的状态,逻辑本分可以...

mysql备份脚本:自己设定用户名密码及数据保留时间

关注我,不迷路,大家好,我是大王。--记录运维中遇到的故障及排查方法一、背景说明今天给大家分享一个mysql数据库的备份脚本二、过程2.1 书写脚本vi mysql-bak.sh#!/bin/bash...