精华内容
下载资源
问答
  • 主要介绍了shell脚本定时备份MySQL数据库数据并保留指定时间,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
  • 备份并清除老日志Shell脚本,并附带一个清除日志(log)的shell脚本代码,需要的朋友可以参考下
  • 需求分析 1)每天凌晨 2:10 备份 数据库 atguiguDB 到 /data/backup/db 2)备份开始和备份结束能够给...shell脚本文件 #!/bin/bash #完成数据库的定时备份。 #备份的路径 BACKUP=/data/backup/db #当前的时间作为文件名

    需求分析
    1)每天凌晨 2:10 备份 数据库 atguiguDB 到 /data/backup/db
    2)备份开始和备份结束能够给出相应的提示信息
    3)备份后的文件要求以备份时间为文件名,并打包成 .tar.gz 的形式,比如:
    2018-03-12_230201.tar.gz
    在备份的同时,检查是否有 10 天前备份的数据库文件,如果有就将其删除。
    shell脚本文件

    #!/bin/bash
    
    #完成数据库的定时备份。
    #备份的路径
    BACKUP=/data/backup/db
    #当前的时间作为文件名
    DATETIME=$(date +%Y_%m_%d_%H%M%S)
    #可以输出变量调试
    #echo ${DATETIME}
    
    echo "=======开始备份========"
    echo "=======备份的路径是 $BACKUP/$DATETIME.tar.gz"												
    
    #主机
    HOST=localhost
    #用户名
    DB_USER=root
    #密码
    DB_PWD=root
    #备份数据库名
    DATABASE=atguiguDB
    #创建备份的路径
    #如果备份的路径文件夹存在,就使用,否则就创建
    [ ! -d "$BACKUP/$DATETIME" ] && mkdir -p "$BACKUP/$DATETIME"
    #执行mysql的备份数据库的指令
    mysqldump -u${DB_USER} -p${DB_PWD} --host=$HOST  $DATABASE | gzip > $BACKUP/$DATETIME/$DATETIME.sql.gz
    #打包备份文件
    cd $BACKUP
    tar -zcvf $DATETIME.tar.gz $DATETIME
    #删除临时目录
    rm -rf $BACKUP/$DATETIME
    
    #删除10天前的备份文件
    find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm -rf {} \;
    echo "=====备份文件成功==========="
    
    
    

    1:需要修改脚本文件为可执行文件 如:chmod 744 mysql_db_backup.sh
    如下命令 查看文件是否是可执行文件
    在这里插入图片描述
    2: 将脚本设置为定时执行
    执行 crontab –e
    输入以下内容并保存,,就会在每天2:10的是时候执行这个脚本
    在这里插入图片描述

    展开全文
  • 编写Shell脚本定时备份数据库

    千次阅读 2019-05-02 18:13:47
    需求 1.每天凌晨2点10分备份数据库atguiguDB到/data/backup/db 2.备份开始和备份结束能够给出相应的提示信息 3.备份后的文件以时间命名,并打包...4.在备份的同事,检查是否有10天前的备份数据库文件,有则删除之 ...

    需求
    1.每天凌晨2点10分备份数据库atguiguDB到/data/backup/db
    2.备份开始和备份结束能够给出相应的提示信息
    3.备份后的文件以时间命名,并打包成.tar.gz形式,如2019-05-01_110101.tar.gz
    4.在备份的同事,检查是否有10天前的备份数据库文件,有则删除之
    《Linux之Shell语法详解》
    源码

    #!/bin/bash
    #数据库的定时备份
    #定义备份的路径
    BACKUP=/var/lib/mysql
    DATETIME=`date +%Y_%m_%d_%H%M%S`
    #echo "$DATETIME"
    echo "=====start backup to $BACKUP/$DATETIME/$DATETIME.tar.gz======"
    #主机
    HOST=localhost
    DB_USER=root
    DB_PWD=798465
    #要备份的数据库名称
    DATABASE=microblog
    #创建备份的路径,如果路径不存在则创建
    [ ! -d "$BACKUP/$DATETIME" ] && mkdir -p "$BACKUP/$DATETIME"
    #执行mysql的备份数据库指令
    mysqldump -u${DB_USER} -p${DB_PWD} --host=$HOST $DATABASE | gzip > $BACKUP/$DATETIME/$DATETIME.sql.gz
    #打包备份文件
    cd $BACKUP
    tar -zcvf $DATETIME.tar.gz $DATETIME
    #删除临时目录
    rm -rf $BACKUP/$DATETIME
    #删除10天前的备份文件
    #在$backup目录下按照时间找10天前的名称为*.tar.gz的文件,-exec表示执行找到的文件
    find $BACKUP -mtime +10 -name "*.tar.gz" -exec rm rf {} \;
    echo "===========backup success======"
    

    测试
    在shell脚本的根目录下执行 ./文件名,然后在定义的/var/lib/mysql路径下可以看到目标文件
    在这里插入图片描述
    解压之后vim打开.sql文件查看是否备份成功
    在这里插入图片描述
    加入定时任务

    crontab -e
    

    在打开的编辑器中输入以下一行代码,表示每晚1点10分执行后面的命令(shell脚本的路径)

    10 1 * * * /opt/workspace/shell/backDB.sh
    

    crontab讲解

    crond 是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务 工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。
    Linux下的任务调度分为两类:系统任务调度用户任务调度
    系统任务调度:系统周期性所要执行的工作比如写缓存数据到硬盘、日志清理等。在/etc目录下有一个crontab文件,这个就是系统任务调度的配置文件。
    用户任务调度:用户定期要执行的工作,比如用户数据备份、定时邮件提醒等。用户可以使用 crontab 工具来定制自己的计划任务。所有用户定义的crontab 文件都被保存在 /var/spool/cron目录中。其文件名与用户名一致。
    使用者权限文件
    文件:/etc/cron.deny
    说明:该文件中所列用户不允许使用crontab命令
    文件:/etc/cron.allow
    说明:该文件中所列用户允许使用crontab命令
    文件:/var/spool/cron/
    说明:所有用户crontab文件存放的目录,以用户名命名
    crontab文件的含义
    用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:
    minute hour day month week command
    minute: 表示分钟,可以是从0到59之间的任何整数。
    hour:表示小时,可以是从0到23之间的任何整数。
    day:表示日期,可以是从1到31之间的任何整数。
    month:表示月份,可以是从1到12之间的任何整数。
    week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。
    command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
    在以上各个字段中,还可以使用以下特殊字符:
    星号( * ):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
    逗号( , ):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
    中杠( - ):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
    正斜线( / ):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。
    使用实例
    实例1:每1分钟执行一次command

    * * * * * command
    

    实例2:每小时的第3和第15分钟执行

    3,15 * * * * command
    

    实例3:在上午8点到11点的第3和第15分钟执行

    3,15 8-11 * * * command
    

    实例4:每隔两天的上午8点到11点的第3和第15分钟执行

    3,15 8-11 */2 * * command
    

    实例5:每个星期一的上午8点到11点的第3和第15分钟执行

    3,15 8-11 * * 1 command
    

    实例6:每晚的21:30重启smb

    30 21 * * * /etc/init.d/smb restart
    

    实例7:每月1、10、22日的4 : 45重启smb

    45 4 1,10,22 * * /etc/init.d/smb restart
    

    实例8:每周六、周日的1 : 10重启smb

    10 1 * * 6,0 /etc/init.d/smb restart
    

    实例9:每天18 : 00至23 : 00之间每隔30分钟重启smb

    0,30 18-23 * * * /etc/init.d/smb restart
    

    实例10:每星期六的晚上11 : 00 pm重启smb

    0 23 * * 6 /etc/init.d/smb restart
    

    实例11:每一小时重启smb

    * */1 * * * /etc/init.d/smb restart
    

    实例12:晚上11点到早上7点之间,每隔一小时重启smb

    * 23-7/1 * * * /etc/init.d/smb restart
    

    实例13:每月的4号与每周一到周三的11点重启smb

    0 11 4 * mon-wed /etc/init.d/smb restart
    

    实例14:一月一号的4点重启smb

    0 4 1 jan * /etc/init.d/smb restart
    

    实例15:每小时执行/etc/cron.hourly目录内的脚本

    01 * * * * root run-parts /etc/cron.hourly
    

    说明:
    run-parts这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是目录名了

    注:crontab讲解部分参考 https://www.cnblogs.com/intval/p/5763929.html

    展开全文
  • 2.编写 shell脚本 #!/bin/bash #:set fileformat=unix docker exec -i 容器名称 bash<<'EOF' if [ ! -d "备份路径" ];then mkdir -p 备份路径 fi mysqldump -u账号 -p密码 数据库名称 > 备份路径/...

    1.在服务器下载安装crontab

    yum -y install vixie-cron
    yum -y install crontabs

     2.编写 shell脚本

    #!/bin/bash
    #:set fileformat=unix
    docker exec -i 容器名称  bash<<'EOF'
    if [ ! -d "备份路径" ];then
      mkdir -p 备份路径
    fi
    mysqldump -u账号 -p密码  数据库名称 > 
    备份路径/数据库名称_$(date +%Y%m%d).sql
    #删除超过10天的数据
    rm -f 备份路径/数据库名称_$(date -d -3day +%Y%m%d).sql
    exit
    EOF
    # 判断目录是不是已经存在,如果不存在则创建
    if [ ! -d "备份路径" ];then
      mkdir -p 备份路径
    fi
    # 将docker中的备份的数据拷贝到宿主机上。
    docker cp 容器名称:备份路径/数据库名称_$(date +%Y%m%d).sql 备份路径
    #删除超过10天的数据
    rm -f 备份路径/数据库名称_$(date -d -3day +%Y%m%d).sql

    3. chmod 700  脚本.sh #给予权限

    4.--如果是通过文件上传的服务器,在服务器上下载一个 需要格式化

    1,yum install dos2unix -y
    2,dos2unix 文件名.sh

    5.增加定时任务

    crontab -uroot -e
    
    1 0 * * *  脚本路径/脚本名称.sh   每天凌晨12点01分执行

     6.重启服务 service crond restart

    展开全文
  • 1.创建一个目录把写好的shell脚本放到该目录下 命令:mkdir -p /opt/mysql/shell 定时任务shell脚本如下(文件命名为:mysqlbackup.sh 以下脚本需更改的地方见步骤2): #!/bin/bash #功能说明:本功能用于备份...

    1.创建一个目录把写好的shell脚本放到该目录下  命令:mkdir -p /opt/mysql/shell    定时任务shell脚本如下(文件命名为:mysqlbackup.sh  以下脚本需更改的地方见步骤2):

    #!/bin/bash
    #功能说明:本功能用于备份mysql数据库
    #编写日期:2021/03/11
    PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:/usr/local/mysql/bin
    export PATH
    #数据库用户名
    dbuser='root'
    #数据库密码
    dbpasswd='123456'
    #数据库名,可以定义多个数据库,中间以空格隔开,如:test test1 test2
    dbname='system_module'
    #备份时间
    backtime=`date +%Y%m%d%H%M%S`
    #日志备份路径
    logpath='/opt/mysqlbackup/log'
    #数据备份路径
    datapath='/opt/mysqlbackup/data'
    #日志记录头部
    echo '开始导出数据库...'
    echo ‘”备份时间为${backtime},备份数据库表 ${dbname} 开始” >> ${logpath}/mysqllog.log
    #正式备份数据库
    for table in $dbname; do
    source=`mysqldump  -u${dbuser} -p${dbpasswd} --single-transaction ${table}> ${datapath}/${table}${backtime}.sql` 2>> ${logpath}/mysqllog.log;
    #备份成功以下操作
    if [ "$?" == 0 ];then

    echo '导出数据库...' ${table}
    echo '开始压缩文件...'
    cd $datapath
    #为节约硬盘空间,将数据库压缩
    tar jcf    ${table}${backtime}.tar.bz2  ${table}${backtime}.sql > /dev/null
    echo '压缩完毕...'
    echo '删除文件...'
    #删除原始文件,只留压缩后文件
    rm -f ${datapath}/${table}${backtime}.sql
    echo “数据库表 ${dbname} 备份成功!!” >> ${logpath}/mysqllog.log
    echo '备份成功...'
    else
    #备份失败则进行以下操作
    echo “数据库表 ${dbname} 备份失败!!” >> ${logpath}/mysqllog.log
    echo '备份失败...'
    fi
    done

    2.需要更改的地方为:

     

    3.切换到刚才建好的shell目录下  测试下  shell执行是否正常    cd /opt/mysql/shell

    4.启动   sh  mysqlbackup.sh  start   启动成功后就能看到备份的mysql  文件

    5.我们可以用cron做定时任务执行 mysqlbackup.sh脚本    cron是linux自带的定时任务执行工具  可以在无需人工干预的情况下运行作业        cron是默认启动的    查看cron的启动状态:  命令:/sbin/service crond status

     

     

    6.在cron文件里加入mysqlbackup.sh脚本   命令编辑cron 文件 :vi /etc/crontab

     

    7.最后去刚才建好的数据库备份目录下查询是否有文件备份成功    切换到数据目录:  cd /opt/mysqlbackup/data

     

    8.解压上面的文件就是我们备份后的脚本    命令:tar jxvf system_module20210311114201.tar.bz2

     

     

    9.备注:

    /sbin/service crond start //启动服务

    /sbin/service crond stop //关闭服务

    /sbin/service crond restart //文字重启服务

    /sbin/service crond reload //重新载入配置

     

     

     

     

    展开全文
  • #!/bin/bash tar -zcf /var/backup/etc_backup`date +20%y-%m-%d`.tar.gz /etc 编辑定时任务#crontab -e0 1 * /root/file_backup.sh 每天凌晨1点执行/etc备份任务 注意:需要事先存在/var/backup目录...
  • 1.创建脚本文件 vim backupmysql.sh 创建脚本内容如下: #!/bin/sh db_user="root" db_passwd="123456" db_name="userdb" name="$(date +"%Y%m%d%H%M%S")" /usr/bin/mysqldump -u$db_user -p$db_passwd $db...
  • 也结合之前研究定时备份脚本,今天来写一篇关于定时备份数据的文章。 我的MySQL是使用docker部署的,所以备份的命令是要通过docker进入容器,再执行备份命令。 #!/bin/bash # 设置mysql的登录用户名和密码(根据...
  • 编写sh脚本 #!/bin/bash #数据库用户名 db_user=root #数据库密码 db_password=password@123 #数据库名称 db_name=databasename #备份存放路径 backup_dir=/usr/local/mysqlbackup/backup_data #备份命名所使用的...
  • 3、es备份脚本: (1)配置文件: (2)代码: (3)配置参数说明: (4)使用注意事项: (5)定时crond配置: 1、es备份说明: 第一个快照会是一个数据的完整拷贝,但是所有后续的快照会保留的是已存快照...
  • 定时备份实现 编写shell脚本文件 db_user="数据库用户" db_password="数据库密码" db_name="需要备份的数据库名" #the directory for story your backup file.you shall change this dir backup_dir="/data/db_...
  • Shell脚本备份数据的博文不少,这个应该算是比较简单的,没有复杂逻辑,分享一下。 1.备份脚本 Shell脚本的每行命令一定要在测试环境进行测试,否则会有意想不到的惊吓????,以下是showDocBackUp.sh的内容。 这里是...
  • 目录 一、前言 二、环境 三、备份方法 四、操作步骤 ...4.1、在备份目录新建back.sh脚本文件 ...4.2、创建定时任务,每天02点执行一次 ...很多项目由于存储空间限制,给...编写shell脚本,利用达梦dexp工具、crontab定.
  • 备份脚本怎么写呢?  在写脚本之前,先假设mysql的bin目录是:/usr/local/mysql/bin/ PATH=$PATH:$HOME/bin #备份目录 BackupPath="/home/mysql/backup" #备份文件名 BackupFile="dbbackup"$(date +%y%m%d_%H...
  • 使用shell脚本定时执行备份mysql数据库 1 #!/bin/bash 2 3 ############### common file ################ 4 5 #本机备份文件存放目录 7 MYSQLBACK_DIR="/data/backup/bak_mysql" 9 10 #格式化...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 15,841
精华内容 6,336
关键字:

shell脚本定时备份文件