自动备份脚本 mysql_hourly_backup.sh

自动备份脚本 mysql_hourly_backup.sh

#!/bin/bash

# MySQL Docker 每小时自动备份脚本
# 作者: Auto Backup Script
# 描述: 每小时自动备份MySQL数据库到指定目录,保留24小时备份

set -e  # 遇到错误立即退出

# 颜色定义
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
NC='\033[0m' # No Color

# 配置变量
MYSQL_CONTAINER="mysql"
MYSQL_USER="root"
MYSQL_PASSWORD="root123"
BACKUP_DIR="/opt/mysql/backups"
LOG_FILE="/var/log/mysql_backup.log"
RETENTION_HOURS=24  # 保留24小时备份(24个备份文件)

# 日志函数
log_info() {
   
   
    echo -e "${BLUE}[$(date '+%Y-%m-%d %H:%M:%S')] [INFO]${NC} $1" | tee -a "$LOG_FILE"
}

log_success() {
   
   
    echo -e "${GREEN}[$(date '+%Y-%m-%d %H:%M:%S')] [SUCCESS]${NC} $1" | tee -a "$LOG_FILE"
}

log_warning() {
   
   
    echo -e "${YELLOW}[$(date '+%Y-%m-%d %H:%M:%S')] [WARNING]${NC} $1" | tee -a "$LOG_FILE"
}

log_error() {
   
   
    echo -e "${RED}[$(date '+%Y-%m-%d %H:%M:%S')] [ERROR]${NC} $1" | tee -a "$LOG_FILE"
}

# 检查依赖
check_dependencies() {
   
   
    if ! command -v docker &> /dev/null; then
        log_error "Docker未安装"
        exit 1
    fi
    
    if ! docker ps | grep -q "$MYSQL_CONTAINER"; then
        log_error "MySQL容器未运行: $MYSQL_CONTAINER"
        exit 1
    fi
}

# 创建备份目录
. mysqldump命令备份数据在MySQL中提供了命令行导出数据库数据以及文件的一种方便的工具mysqldump,我们可以通过命令行直接实现数据库内容的导出dump,首先我们简单了解一下mysqldump命令用法:#MySQLdump常用mysqldump -u root -p --databases 数据库数据库2 > xxx.sql二. mysqldump常用操作示例1.备份全部数据库的数据和结构mysqldump -uroot -p123456 -A > /data/mysqlDump/mydb.sql2.备份全部数据库的结构(加 -d 参数)mysqldump -uroot -p123456 -A -d > /data/mysqlDump/mydb.sql3.备份全部数据库的数据(加 -t 参数)mysqldump -uroot -p123456 -A -t > /data/mysqlDump/mydb.sql4.备份单个数据库的数据和结构(,数据库名mydb)mysqldump -uroot-p123456 mydb > /data/mysqlDump/mydb.sql5. 备份单个数据库的结构mysqldump -uroot -p123456 mydb -d > /data/mysqlDump/mydb.sql6. 备份单个数据库的数据mysqldump -uroot -p123456 mydb -t > /data/mysqlDump/mydb.sql7. 备份多个表的数据和结构(数据,结构的单独备份方法与上同)mysqldump -uroot -p123456 mydb t1 t2 > /data/mysqlDump/mydb.sql8. 一次备份多个数据库mysqldump -uroot -p123456 --databases db1 db2 > /data/mysqlDump/mydb.sql三. 还原 MySQL 备份内容有两种方式还原,第一种是在 MySQL 命令行中,第二种是使用 SHELL 行完成还原1.在系统命令行中,输入如下实现还原:mysql -uroot -p123456 < /data/mysqlDump/mydb.sql2.在登录进入mysql系统中,通过source指令找到对应系统中的文件进行还原:mysql> source /data/mysqlDump/mydb.sql在 Linux中,通常使用BASH脚本对需要执行的内容进行编写,加上定时执行命令crontab实现日志自动化生成。以下代码功能就是针对mysql进行备份,配合crontab,实现备份的内容为近一个月(31天)内的每天的mysql数据库记录。编写BASH维护固定数量备份文件在Linux中,使用vi或者vim编写脚本内容并命名为:mysql_dump_script.sh#!/bin/bash #保存备份个数,备份31天数据number=31#备份保存路径backup_dir=/root/mysqlbackup#日期dd=`date +%Y-%m-%d-%H-%M-%S`#备份工具tool=mysqldump#用户名username=root#密码password=TankB214#将要备份数据库database_name=edoctor #如果文件夹不存在则创建if [ ! -d $backup_dir ];then         mkdir -p $backup_dir;fi #简单写法 mysqldump -u root -p123456 users > /root/mysqlbackup/users-$filename.sql$tool -u $username -p$password $database_name > $backup_dir/$database_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 -1` #判断现在的备份数量是否大于$numbercount=`ls -l -crt $backup_dir/*.sql | awk '{print $9 }' | wc -l` if [ $count -gt $number ]then  #删除最早生成的备份,只保留number数量的备份  rm $delfile  #写删除文件日志  echo "delete $delfile" >> $backup_dir/log.txtfi如上代码主要含义如下:1.首先设置各项参数,例如number最多需要备份的数目,备份路径,用户名,密码等。2.执行mysqldump命令保存备份文件,并将操作打印至同目录下的log.txt中标记操作日志。3.定义需要删除的文件:通过ls命令获取第九列,即文件名列,再通过实现定义操作时间最晚的那个需要删除的文件。4.定义备份数量:通过ls命令加上wc -l统计以sql结尾的文件的行数。5.如果文件超出限制大小,就删除最早创建的sql文件使用crontab定期执行备份脚本在 Linux 中,周期执行的任务一般由cron这个守护进程来处理[ps -ef|grep cron]。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。cron的配置文件称为“crontab”,是“cron table”的简写。cron服务cron是一个 Liunx 下 的定时执行工具,可以在无需人工干预的情况下运行作业。service crond start    //启动服务service crond stop     //关闭服务service crond restart  //重启服务service crond reload   //重新载入配置service crond status   //查看服务状态 crontab语法crontab命令用于安装、删除或者列出用于驱动cron后台进程的表格。用户把需要执行的命令序列放到crontab文件中以获得执行。每个用户都可以有自己的crontab文件。/var/spool/cron下的crontab文件不可以直接创建或者直接修改。该crontab文件是通过crontab命令创建的。在crontab文件中如何输入需要执行的命令和时间。该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。每个域之间使用空格或者制表符分隔。格式如下:minute hour day-of-month month-of-year day-of-week commands 合法值 00-59 00-23 01-31 01-12 0-6 (0 is sunday)  除了数字还有几个个特殊的符号就是"*"、"/"和"-"、",",*代表所有的取值范围内的数字,"/"代表每的意思,"/5"表示每5个单位,"-"代表从某个数字到某个数字,","分开几个离散的数字。 -l 在标准输出上显示当前的crontab。 -r 删除当前的crontab文件。 -e 使用VISUAL或者EDITOR环境变量所指的编辑器编辑当前的crontab文件。当结束编辑离开时,编辑后的文件将自动安装。 创建cron脚本第一步:写cron脚本文件,命名为mysqlRollBack.cron。15,30,45,59 * * * * echo "xgmtest....." >> xgmtest.txt  表示,每隔15分钟,执行打印一次命令第二步:添加定时任务。执行命令 “crontab crontest.cron”。搞定第三步:"crontab -l" 查看定时任务是否成功或者检测/var/spool/cron下是否生成对应cron脚本注意:这操作是直接替换该用户下的crontab,而不是新增定期执行编写的定时任务脚本(记得先给shell脚本执行权限)0 2 * * * /root/mysql_backup_script.sh随后使用crontab命令定期指令编写的定时脚本crontab mysqlRollback.cron再通过命令检查定时任务是否已创建:附 crontab 的使用示例:1.每天早上6点0 6 * * * echo "Good morning." >> /tmp/test.txt //注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。2.每两个小时0 */2 * * * echo "Have a break now." >> /tmp/test.txt3.晚上11点到早上8点之间每两个小时和早上八点0 23-7/2,8 * * * echo "Have a good dream" >> /tmp/test.txt4.每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点0 11 4 * 1-3 command line5.1月1日早上4点0 4 1 1 * command line SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root //如果出现错误,或者有数据输出,数据作为邮件发给这个帐号 HOME=/6.每小时执行/etc/cron.hourly内的脚本01 * * * * root run-parts /etc/cron.hourly7.每天执行/etc/cron.daily内的脚本02 4 * * * root run-parts /etc/cron.daily8.每星期执行/etc/cron.weekly内的脚本22 4 * * 0 root run-parts /etc/cron.weekly9.每月去执行/etc/cron.monthly内的脚本42 4 1 * * root run-parts /etc/cron.monthly注意: "run-parts" 这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名。10.每天的下午4点、5点、6点的5 min、15 min、25 min、35 min、45 min、55 min时执行命令。5,15,25,35,45,55 16,17,18 * * * command11.每周一,三,五的下午3:00系统进入维护状态,重新启动系统。00 15 * * 1,3,5 shutdown -r +512.每小时的10分,40分执行用户目录下的innd/bbslin这个指令:10,40 * * * * innd/bbslink13.每小时的1分执行用户目录下的bin/account这个指令:1 * * * * bin/account以下是我的测试每分钟的截图效果,其对应代码如下:* * * * * /root/mysql_backup_script.sh效果截图:其中的log.txt记录备份的操作详细日志:来源:cnblogs.com/letcafe/p/mysqlautodump.html
04-08
<think>我们已知用户要求为两个字段分别添加单独的索引(非复合索引),因此需要在建表语句后添加两个独立的CREATEINDEX语句。注意:原建表语句中可能已经包含某些索引,但用户要求新增两个单独索引,因此我们需要在原语句基础上补充。如果原表已经存在同名字段的主键或唯一约束,可能需要调整,但用户没有提供完整建表语句,所以我们假设原表没有这两个字段的索引。用户提供的建表语句不完整,但我们知道表名为SG_DEV_ACLINE_HOURLY_DATA,需要添加索引的字段是ACLINEEND_ID和CREATE_DATE。因此,我们将在建表语句之后,添加两条创建索引的语句:CREATEINDEXidx_acl_end_idONSG_DEV_ACLINE_HOURLY_DATA(ACLINEEND_ID);CREATEINDEXidx_create_dateONSG_DEV_ACLINE_HOURLY_DATA(CREATE_DATE);但是,由于用户没有提供完整的建表语句(用...代替),我们无法直接写出完整的表结构,因此只能提供修改部分的示例。假设原建表语句为:CREATETABLESG_DEV_ACLINE_HOURLY_DATA(...//这里省略了表的具体列定义);修改后的语句就是在原建表语句后追加两个CREATEINDEX语句。注意:如果表已经创建,我们可以直接执行两条CREATEINDEX语句,但用户要求修改建表语句,所以我们需要给出完整的SQL脚本,包括建表语句和索引创建语句。但是,为了避免因表结构缺失导致的错误,我们只能给出索引创建部分的语句,并说明在原建表语句之后添加。然而,用户要求“包含完整的建表语句”,所以我们有两种做法:1.用户提供完整的原建表语句,我们在此基础上修改。2.由于用户没有提供完整建表语句,我们只能假设一个表结构,然后补充索引。由于问题中用户没有提供完整表结构,我们无法得知完整的列定义。因此,我们可以这样处理:-首先,我们假设表结构中已经包含了这两个字段(因为用户要求为它们创建索引)。-然后,我们在原建表语句的末尾(在右括号之后)加上分号结束建表语句,再单独写两个创建索引的语句。例如:原建表语句(假设):CREATETABLESG_DEV_ACLINE_HOURLY_DATA(IDNUMBERPRIMARYKEY,ACLINEEND_IDNUMBER,CREATE_DATEDATE,...//其他字段);修改后,变成:CREATETABLESG_DEV_ACLINE_HOURLY_DATA(IDNUMBERPRIMARYKEY,ACLINEEND_IDNUMBER,CREATE_DATEDATE,...//其他字段);CREATEINDEXidx_acl_end_idONSG_DEV_ACLINE_HOURLY_DATA(ACLINEEND_ID);CREATEINDEXidx_create_dateONSG_DEV_ACLINE_HOURLY_DATA(CREATE_DATE);注意:索引名称是自定义的,这里使用idx_acl_end_id和idx_create_date,但实际中可以根据需要修改。然而,用户可能要求在一个脚本中执行,所以我们需要将这三条语句按顺序写在一个脚本中。另外,如果用户要求在建表语句内部定义索引(即在CREATETABLE语句中直接定义索引),那么语法如下(但通常单独索引都是单独创建的):在CREATETABLE语句内定义索引(Oracle语法):CREATETABLESG_DEV_ACLINE_HOURLY_DATA(...,INDEXidx_acl_end_id(ACLINEEND_ID),INDEXidx_create_date(CREATE_DATE));但是,不是所有的数据库都支持在CREATETABLE语句内创建普通索引(Oracle不支持,MySQL支持)。因此,为了通用性,通常采用在表创建后单独创建索引。考虑到用户没有指定数据库类型,我们使用通用的方式:单独创建索引。因此,我们最终的答案就是给出一个包含建表语句(假设用户提供的是完整语句,我们这里用省略号代替)和两个创建索引的完整SQL脚本。由于原建表语句不完整,我们只能保留原样,然后在后面添加两个索引语句。所以,我们这样修改:原语句:CREATETABLESG_DEV_ACLINE_HOURLY_DATA(...);修改后的完整脚本:CREATETABLESG_DEV_ACLINE_HOURLY_DATA(...--这里保持用户原来的表结构);CREATEINDEXidx_acl_end_idONSG_DEV_ACLINE_HOURLY_DATA(ACLINEEND_ID);CREATEINDEXidx_create_dateONSG_DEV_ACLINE_HOURLY_DATA(CREATE_DATE);这样,当用户运行这个脚本时,会先创建表,然后为两个字段分别创建索引。注意:索引名称可以更改,这里仅作示例。如果用户希望避免重复创建索引,可以加上判断,但在建表脚本中通常不需要,因为表是新创建的。如果是在已存在的表上添加索引,则只需执行两个CREATEINDEX语句。但用户要求的是修改建表语句,所以我们给出的是一整个创建表并添加索引的脚本。现在,我们按照这个思路来组织答案。</think> 要分别为`ACLINEEND_ID`和`CREATE_DATE`字段添加单独的索引,需要在建表语句后追加独立的`CREATE INDEX`语句。以下是修改后的完整SQL脚本,其中`...`表示您原有的表结构定义部分: ```sql -- 创建数据表(保持您原有的表结构) CREATE TABLE SG_DEV_ACLINE_HOURLY_DATA ( ... -- 您原有的列定义保持不变 ); -- 为ACLINEEND_ID字段添加独立索引 CREATE INDEX idx_acl_end_id ON SG_DEV_ACLINE_HOURLY_DATA (ACLINEEND_ID); -- 为CREATE_DATE字段添加独立索引 CREATE INDEX idx_create_date ON SG_DEV_ACLINE_HOURLY_DATA (CREATE_DATE); ``` ### 关键说明: 1. **索引命名规则**: - `idx_acl_end_id`:表示`ACLINEEND_ID`字段的索引(名称可自定义) - `idx_create_date`:表示`CREATE_DATE`字段的索引(名称可自定义) 2. **执行顺序**: - 先创建表结构 → 后添加索引(避免锁表冲突) 3. **索引效果**: - `ACLINEEND_ID`索引:加速基于端点ID的查询和关联操作 - `CREATE_DATE`索引:优化时间范围查询(如按日期筛选) 4. **兼容性**: - 语法兼容Oracle/MySQL/PostgreSQL等主流数据库 ### 实际应用建议: 1. 数据量较大时(>100万行),建议在业务低峰期执行索引创建 2. 定期检查索引碎片率:`ANALYZE INDEX idx_name VALIDATE STRUCTURE;` (Oracle)[^1] 3. 监控索引使用频率,及时清理无效索引
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科学熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值