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. 实际使用

    编辑截图

​ 一行存一条命令

相关推荐
theo.wu几秒前
使用Buildpacks构建Docker镜像
运维·docker·容器
玉树临风江流儿10 分钟前
Linux驱动开发(速记版)--设备模型
linux·驱动开发
杰哥在此23 分钟前
Python知识点:如何使用Multiprocessing进行并行任务管理
linux·开发语言·python·面试·编程
Code成立29 分钟前
1、深入理解Redis线程模型
数据库·redis·bootstrap
缘友一世2 小时前
macos安装mongodb
数据库·mongodb·macos
枫叶丹42 小时前
【在Linux世界中追寻伟大的One Piece】进程信号
linux·运维·服务器
刻词梨木3 小时前
ubuntu中挂载点内存不足,分配不合理后使用软链接的注意事项
linux·运维·ubuntu
灯火不休ᝰ3 小时前
[win7] win7系统的下载及在虚拟机中详细安装过程(附有下载文件)
linux·运维·服务器
万事大吉CC4 小时前
mysql单表查询·3
数据库·mysql
bin91534 小时前
【EXCEL数据处理】000010 案列 EXCEL文本型和常规型转换。使用的软件是微软的Excel操作的。处理数据的目的是让数据更直观的显示出来,方便查看。
大数据·数据库·信息可视化·数据挖掘·数据分析·excel·数据可视化