7.1 Mysql shell 定时备份

  1. 直接上脚本----linu 定时任务执行
shell 复制代码
#!/bin/bash

# 配置信息
DB_USER="your_username" # 数据库用户名
DB_PASSWORD="your_password" # 数据库密码
DB_NAME="your_database_name" # 要备份的数据库名
BACKUP_DIR="/path/to/backup/directory" # 备份文件存储路径
DATE=$(date +%Y%m%d%H%M%S) # 当前日期,用于文件命名
LOG_FILE="/path/to/log/file.log" # 日志文件路径

# 创建备份目录(如果不存在)
mkdir -p ${BACKUP_DIR}

# 执行备份命令,并将输出重定向到日志文件
mysqldump -u${DB_USER} -p${DB_PASSWORD} ${DB_NAME} > ${BACKUP_DIR}/${DB_NAME}_${DATE}.sql 2>> ${LOG_FILE}

# 检查上一个命令的退出状态,如果不是0(表示出错),则记录错误信息到日志文件
if [ $? -ne 0 ]; then
    echo "[ERROR] Backup failed on $(date). Check ${LOG_FILE} for details." >> ${LOG_FILE}
else
    echo "[INFO] Backup successful on $(date)." >> ${LOG_FILE}
fi
  1. 使用说明:

    a. 将上述脚本保存为一个.sh文件,例如mysql_backup.sh。

    b. 修改脚本中的配置信息,包括数据库用户名、密码、要备份的数据库名、备份文件存储路径和日志文件路径。

    c. 通过chmod +x mysql_backup.sh命令赋予脚本执行权限。

    d. 可以通过crontab -e命令添加定时任务

    例如: 每天凌晨1点执行备份:

    0 1 * * * /path/to/mysql_backup.sh

    脚本会自动在指定的备份目录下生成以日期时间为文件名的备份文件,并在日志文件中记录备份成功或失败的信息。

  2. linux 定时任务使用 crond服务

    1. 安装crontab:

      yum install crontabs

      服务操作说明:

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

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

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

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

      查看crontab服务状态:

      service crond status

      手动启动crontab服务:

      service crond start

      查看crontab服务是否已设置为开机启动,执行

      ntsysv

      加入开机自动启动:

      chkconfig --level 35 crond on

    2. crontab命令详解

      1.命令格式:

      crontab [-u user] file

      crontab [-u user] [ -e | -l | -r ]

      2.命令功能:

      通过crontab 命令,我们可以在固定的间隔时间执行指定的系统指令或 shell script脚本。时间间隔的单位可以是分钟、小时、日、月、周及以上的任意组合。这个命令非常设合周期性的日志分析或数据备份等工作。

      3.命令参数:

      -u user:用来设定某个用户的crontab服务,例如,"-u ixdba"表示设定ixdba用户的crontab服务,此参数一般有root用户来运行。

      file:file是命令文件的名字,表示将file做为crontab的任务列表文件并载入crontab。如果在命令行中没有指定这个文件,crontab命令将接受标准输入(键盘)上键入的命令,并将它们载入crontab。

      -e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件。

      -l:显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容。

      -r:从/var/spool/cron目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件。

      -i:在删除用户的crontab文件时给确认提示。

  3. 使用实例

    实例1:每1分钟执行一次

    shell 复制代码
    * * * * *  

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

    shell 复制代码
    3,15 * * * * 

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

    shell 复制代码
    3,15 8-11 * * * 

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

    shell 复制代码
    3,15 8-11 */2 * * 

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

    shell 复制代码
    3,15 8-11 * * 1  

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

    shell 复制代码
    30 21 * * * /etc/init.d/smb restart 

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

    shell 复制代码
    45 4 1,10,22 * * /etc/init.d/smb restart 

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

    shell 复制代码
    10 1 * * 6,0 /etc/init.d/smb restart 

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

    shell 复制代码
    0,30 18-23 * * * /etc/init.d/smb restart 

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

    shell 复制代码
    0 23 * * 6 /etc/init.d/smb restart

    实例11:每一小时重启smb

    shell 复制代码
    * */1 * * * /etc/init.d/smb restart

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

    shell 复制代码
    * 23-7/1 * * * /etc/init.d/smb restart

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

    shell 复制代码
    0 11 4 * mon-wed /etc/init.d/smb restart

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

    shell 复制代码
    0 4 1 jan * /etc/init.d/smb restart

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

    shell 复制代码
    01  *  *  *  *   root run-parts /etc/cron.hourly

    说明:

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

  4. 实际使用

    编辑截图

​ 一行存一条命令

相关推荐
DO_Community11 分钟前
DigitalOcean Droplet 云服务器:新增自动扩展池功能
服务器
安科瑞刘鸿鹏15 分钟前
老旧小区用电安全保护装置#限流式防火保护器参数介绍#
运维·服务器·物联网·能源
ladymorgana23 分钟前
【运维笔记】windows 11 中提示:无法成功完成操作,因为文件包含病毒或潜在的垃圾软件。
运维·windows·笔记
Rain_Rong34 分钟前
linux检测硬盘
linux·运维·服务器
过过过呀Glik37 分钟前
在 Ubuntu 上安装 Muduo 网络库的详细指南
linux·c++·ubuntu·boost·muduo
我曾经是个程序员1 小时前
鸿蒙学习记录之http网络请求
服务器·学习·http
Hello.Reader1 小时前
Redis热点数据管理全解析:从MySQL同步到高效缓存的完整解决方案
redis·mysql·缓存
李昊哲小课1 小时前
deepin 安装 zookeeper
大数据·运维·zookeeper·debian·hbase
真真-真真1 小时前
WebXR
linux·运维·服务器
是程序喵呀2 小时前
MySQL备份
android·mysql·adb