MYSQL数据备份之mysqldump命令详解(附脚本定时备份)

本文详细介绍了MySQL的备份命令,包括cp、mysqldump和xtrabackup的优缺点及应用场景。重点讲解了mysqldump的使用,包括登录选项、备份选项以及如何查看和修改用户权限。同时,提供了多种备份和恢复的命令示例,并展示了一个自动化备份脚本,包括设定保留备份的数量。此外,还提到了热备份、温备份和冷备份的概念。
摘要由CSDN通过智能技术生成
一、常见备份命令介绍
备份命令备份速度恢复速度介绍功能一般用于
cp物理备份、灵活性低很弱少量数据备份
mysqldump逻辑备份、适用所有存储引擎一般中小型数据量备份
xtrabackup较快较快实现innodb热备、对存储引擎有要求强大较大规模的备份

热备份指的是当数据库进行备份时, 数据库的读写操作均不是受影响
温备份指的是当数据库进行备份时, 数据库的读操作可以执行,但是不能执行写操作
冷备份指的是当数据库进行备份时, 数据库不能进行读写操作, 即数据库要下线

二、mysqldump备份

2.1、mysqldump命令介绍

[root@]> mysqldump -help

Usage: mysqldump [OPTIONS] database_name [tables]
OR     mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
OR     mysqldump [OPTIONS] --all-databases [OPTIONS]
For more options, use mysqldump --help
1.登录选项:
    -u user:指定用户
    -h host:指定主机
    -p:表示要使用密码
    -E, --events: 备份事件调度器
    -R, --routines: 备份存储过程和存储函数
2.备份选项:
    --all-databases:备份所有数据库
    --databases db1 db2:备份指定的数据库
    --single-transaction:对事务引擎执行热备
    --flush-logs:更新二进制日志文件
    --master-data=2
        1:每备份一个库就生成一个新的二进制文件(默认)
        2:只生成一个新的二进制文件
    --quick:在备份大表时指定该选项
2.2、查看所属数据库、用户的权限

1、查看mysql数据库中的所有用户:

mysql>SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

2、查看数据库中具体某个用户的权限:

mysql> show grants for 'user'@'localhost'; 
或
mysql> select * from mysql.user where user='root'\G; 

3、修改用户权限:

mysql> grent all on *.* to `user`@`localhost`;
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec).

4、向数据库施加读锁

mysql> FLUSH TABLES WITH READ LOCK;   
Query OK, 0 rows affected (0.00 sec)
三、命令备份示例
**导出命令大全**
#导出education数据库里面的users表的表数据和表结构
	mysqldump -u[用户名] -h[ip] -p[密码] -P[端口号] 数据库名 表名 >导出的文件名.sql
	mysqldump -uroot -h127.0.0.1 -proot -P3306 education users>d:/user.sql
#导出包括系统数据库在内的所有数据库(all.sql默认保存在bin文件夹下面)
	mysqldump -uroot -proot --all-databases>all.sql
#导出多张表:
	mysqldump -uroot -proot --databases test --tables t1 t2>two.sql
#只导出表结构不导表数据,添加“-d”命令参数
    mysqldump -uroot -h127.0.0.1 -proot -P3306 -d education users>d:/user.sql
#只导出表数据不导表结构,添加“-t”命令参数
    mysqldump -uroot -h127.0.0.1 -proot -P3306 -t education users>d:/user.sql
#只导出test数据库的表结构
 导出:mysqldump -uroot -proot --no-data --databases test>s1.sql
 导入:mysql -uroot -proot -h127.0.0.1 -P3306 test<s1.sql
 
**导入命令大全**
 格式:mysql -h[ip] -P[(大写)端口] -u[用户名] -p[密码]  [数据库名] < d:XX.sql(路径) 
 	mysql -uroot -proot -h127.0.0.1 -P3306 education<d:/database.sql
 	mysql -uroot -proot -h127.0.0.1 -P3306 <d:/all_database.sql 
#命令行导入
  mysql> use test;
  mysql> source /home/test/database.sql
四、脚本备份示例:
#!/bin/bash
#NAME:数据库备份
#DATE:*/*/*
#USER:***

#设置本机数据库登录信息
mysql_user="user"
mysql_password="passwd"
mysql_host="localhost"
mysql_port="3306"
mysql_charset="utf8mb4"
date_time=`date +%Y-%m-%d-%H-%M`

#保存目录中的文件个数
count=10
#备份路径
path=/***/

#备份数据库sql文件并指定目录
mysqldump --all-databases --single-transaction --flush-logs --master-data=2 -h$mysql_host -u$mysql_user -p$mysql_password > $path_$(date +%Y%m%d_%H:%M).sql
[ $? -eq 0 ] && echo "-----------------数据备份成功_$date_time-----------------" || echo "-----------------数据备份失败-----------------"

#找出需要删除的备份
delfile=`ls -l -crt $path/*.sql | awk '{print $9 }' | head -1`
#判断现在的备份数量是否大于阈值
number=`ls -l -crt $path/*.sql | awk '{print $9 }' | wc -l`
if [ $number -gt $count ]
then
          rm $delfile  #删除最早生成的备份,只保留count数量的备份
                                           #更新删除文件日志
            echo "-----------------已删除过去备份sql $delfile-----------------"
    fi

增加定时备份

crontab -e

*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----------星期中星期几 (0 - 6) (星期天 为0)
|    |    |    +---------------月份 (1 - 12) 
|    |    +--------------------一个月中的第几天 (1 - 31)
|    +-------------------------小时 (0 - 23)
+------------------------------分钟 (0 - 59)

添加定时任务(每天12:50以及23:50执行备份操作)
50 12,23 * * * cd /home/;sh backup.sh >> log.txt
MySQL定时备份可以使用mysqldump命令。mysqldumpMySQL提供的备份工具,可以将数据库导出为SQL文件。 要使用mysqldump命令进行定时备份,可以使用以下步骤: 1. 创建一个备份脚本:在你的服务器上创建一个脚本文件,比如backup.sh。 2. 编辑备份脚本:使用文本编辑器打开备份脚本,并添加以下内容: ```bash #!/bin/bash DATE=$(date +"%Y%m%d%H%M%S") BACKUP_DIR="/path/to/backup/directory" DB_USER="your_database_user" DB_PASS="your_database_password" DB_NAME="your_database_name" mysqldump -u $DB_USER -p$DB_PASS $DB_NAME > $BACKUP_DIR/$DB_NAME-$DATE.sql ``` 将上面的脚本中的`/path/to/backup/directory`替换为你想要存储备份文件的目录路径,`your_database_user`和`your_database_password`替换为你的数据库的用户名和密码,`your_database_name`替换为你要备份的数据库名称。 3. 添加执行权限:在终端中使用`chmod +x backup.sh`命令为备份脚本添加执行权限。 4. 测试备份脚本:在终端中运行`./backup.sh`命令来测试备份脚本是否正常工作。如果一切正常,将会生成一个以当前日期和时间命名的SQL备份文件。 5. 设置定时任务:使用cron来设置定时任务,使备份脚本自动执行。运行`crontab -e`命令编辑cron定时任务配置文件,并添加以下内容: ``` 0 0 * * * /path/to/backup.sh ``` 这将在每天的午夜零点自动执行备份脚本。可以根据需要调整定时任务的时间间隔。 保存并退出cron配置文件。 现在,你的MySQL定时备份就设置好了。每天的午夜零点,备份脚本将会执行,并生成一个新的备份文件。你可以根据需要调整备份脚本定时任务的设置。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值