编写一个shell脚本,实现每隔两个小时对mysql8.0.30 的数据库进行增量备份,MySQL是用docker搭建的
时间: 2023-12-14 16:37:33 浏览: 34
以下是一个简单的shell脚本,可以实现每隔两个小时对mysql8.0.30的数据库进行增量备份:
```shell
#!/bin/bash
# 定义备份目录和文件名
BACKUP_DIR=/path/to/backup
DATE=$(date +%Y-%m-%d_%H-%M-%S)
FILENAME=backup-$DATE.sql
# 进入MySQL容器
docker exec -it mysql-container-name sh -c 'exec mysqldump --single-transaction --order-by-primary --skip-add-drop-table --skip-comments --skip-lock-tables --skip-tz-utc -u root -p"$MYSQL_ROOT_PASSWORD" database-name' > $BACKUP_DIR/$FILENAME
# 判断备份是否成功
if [ $? -eq 0 ]; then
echo "Backup successful"
else
echo "Backup failed"
fi
```
将上述代码保存为一个shell脚本文件,例如`backup.sh`。然后,使用cron作业调度程序,设置计划任务每隔两个小时运行一次该脚本文件即可:
```
0 */2 * * * /path/to/backup.sh
```
上述计划任务表示每隔两个小时运行一次`/path/to/backup.sh`文件。
相关问题
编写一个shell脚本,实现每隔两个小时对mysql8.0.30 的数据库进行备份,MySQL是用docker搭建的
以下是一个简单的脚本,可以实现每隔两个小时对MySQL 8.0.30进行备份:
```bash
#!/bin/bash
# 定义备份路径、数据库名称、docker容器名称、docker镜像名称
BACKUP_DIR="/path/to/backup/directory"
DB_NAME="your_db_name"
CONTAINER_NAME="your_container_name"
IMAGE_NAME="mysql:8.0.30"
# 判断备份目录是否存在,不存在则创建备份目录
if [ ! -d $BACKUP_DIR ]; then
mkdir -p $BACKUP_DIR
fi
# 备份数据库
docker exec $CONTAINER_NAME sh -c "exec mysqldump --single-transaction -h localhost -u root -p'your_db_password' $DB_NAME" > $BACKUP_DIR/$(date +%Y%m%d-%H%M%S).sql
# 删除旧的备份文件,只保留最近的5个备份文件
ls -tp $BACKUP_DIR/*.sql | tail -n +6 | xargs -I {} rm -- {}
# 删除旧的docker容器
docker rm -f $CONTAINER_NAME
# 启动新的docker容器
docker run --name $CONTAINER_NAME -e MYSQL_ROOT_PASSWORD=your_db_password -d $IMAGE_NAME
```
将上述脚本保存为一个名为`backup.sh`的文件,然后使用`crontab`设置定时任务:
```bash
crontab -e
```
在打开的文本编辑器中,添加以下内容:
```
0 */2 * * * /bin/bash /path/to/backup.sh
```
这将在每两个小时的0分执行备份脚本。保存并退出编辑器即可。
编写一个shell脚本,实现每天2点对 mysql8.0.30 的数据库warp进行全量备份,然后再每隔2小时在全量的基础上进行增量备份,MySQL是用docker搭建的
可以按照以下步骤编写shell脚本实现备份:
1. 创建一个名为 `backup.sh` 的文件,并添加可执行权限:
```bash
touch backup.sh
chmod +x backup.sh
```
2. 在 `backup.sh` 文件中添加以下内容:
```bash
#!/bin/bash
# 定义变量
MYSQL_CONTAINER_NAME="mysql"
MYSQL_ROOT_PASSWORD="your_mysql_root_password"
BACKUP_DIR="./backup"
BACKUP_TIME=$(date "+%Y-%m-%d-%H-%M-%S")
# 创建备份目录
if [ ! -d ${BACKUP_DIR} ]
then
mkdir ${BACKUP_DIR}
fi
# 全量备份
docker exec ${MYSQL_CONTAINER_NAME} mysqldump -uroot -p${MYSQL_ROOT_PASSWORD} --single-transaction --flush-logs --master-data=2 warp > ${BACKUP_DIR}/warp-full-${BACKUP_TIME}.sql
# 增量备份
while true
do
sleep 2h
BACKUP_TIME=$(date "+%Y-%m-%d-%H-%M-%S")
docker exec ${MYSQL_CONTAINER_NAME} mysqldump -uroot -p${MYSQL_ROOT_PASSWORD} --single-transaction --flush-logs --master-data=2 --databases warp > ${BACKUP_DIR}/warp-incremental-${BACKUP_TIME}.sql
done
```
3. 修改脚本中的变量,将 `MYSQL_CONTAINER_NAME` 改为你的MySQL容器名称,`MYSQL_ROOT_PASSWORD` 改为你的MySQL root密码,`BACKUP_DIR` 改为你想要存储备份文件的目录。
4. 执行脚本:
```bash
./backup.sh
```
这样就可以实现每天2点进行全量备份,然后每隔2小时进行增量备份。