服务器(Linux\Ubuntu)定时备份数据库

本文介绍如何通过编写Shell脚本实现数据库的定期备份,并利用cron设置自动化的备份任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、编写脚本文件

1-1:新建一个工作目录
cd /opt
mkdir copyDB
1-2:新建脚本文件
cd copuDB
touch copy.sh
1-3:编辑文件
vi copy.sh
1-4:写入脚本
#!/bin/sh
### BEGIN INIT INFO
# Provides: starter
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: start starter
# Description: start starter
### END INIT INFO

#数据库用户名
DB_USER="root"
#数据库密码
DB_PASS="123456"
#数据库地址
DB_HOST="192.168.2.69"
#要备份的表名
DB_NAME="xxxx"
#日期
DATE=`date +%F`
#文件保存的路径
DIR='/opt/copyDB/DB'


mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME > $DIR/DB_$DATE.sql

如果报错:mysqldump: not found则需要安装mysqldump

apt install mysql-client-core-8.0
1-5:修改脚本权限
chmod 777 copy.sh
1-6:创建备份文件夹
mkdir DB
1-7:测试脚本
./copy.sh

查看是否有报错;查看DB文件夹内是否有新文件产生;打开DB文件夹内的文件,查看是否有内容。

二、创建定时任务

cron是一个Linux定时执行工具,可以在无需人工干预的情况下运行作业。在Ubuntu中,cron是被默认安装并启动的。

2-1:编辑ect下crontab文件
vi /etc/crontab
2-2:写入定时任务
00 08   * * *   root    /opt/copyDB/copy.sh
2-3:crontab定时任务语法
minute   hour   day   month   week  user  command    
 #即:分 时 日 月 周 用户 命令
minute: 表示分钟,可以是从 059 之间的任何整数。
 
hour:表示小时,可以是从 023 之间的任何整数。
 
day:表示日期,可以是从 131 之间的任何整数。
 
month:表示月份,可以是从 112 之间的任何整数。
 
week:表示星期几,可以是从 07 之间的任何整数,这里的 07 代表星期日。
 
user:linux的用户身份,例如root,或者其他用户
 
command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。

星号(*):代表所有可能的值,例如 month 字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
 
逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
 
中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
 
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,\
例如*/10,如果用在 minute 字段,表示每十分钟执行一次。
2-4:crontab操作命令
#启动服务
service cron start
#关闭服务
service cron stop
#重启服务
service cron restart
#重新载入配置
service cron reload
#查看crond状态
service cron status
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值