写点什么

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

作者:zhengzai7
  • 2023-07-13
    陕西
  • 本文字数:827 字

    阅读完需:约 3 分钟

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

一、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`# 判断现在的备份数量是否大雨$numbercount=`ls -l -crt $backup_dir/*sql | awk '{print}' | wc -l`if [.$count -gt $number ]then    # 删除最早生成的备份,只保留number数量的备份    rm $delfile    # 写删除文件日志    echo "delete $delfile" >> $backup_dir/log.txtfi
复制代码


二、linux 的 crontab 调度

crontab -e0 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
复制代码


用户头像

zhengzai7

关注

还未添加个人签名 2023-07-07 加入

还未添加个人简介

评论

发布
暂无评论
linux环境用mysqldump定时备份Mysql数据_MySQL_zhengzai7_InfoQ写作社区