shell脚本每天自动备份mysql数据库

12 篇文章 0 订阅
6 篇文章 0 订阅

安装 crontab


检测是否已安装 crontab

# crontab
-bash: crontab: command not found 

那说明没有安装 crontab 

开始安装:

# yum -y install vixie-cron

等待安装完成即可.

编写备份数据库shell

vim /usr/java/shell/bak_mysql.sh

脚本内容如下:

[plain] view plain copy
  1. #!/bin/bash  
  2. # @Author:  hwj  
  3. # @Date:    2017-09-02  
  4. # @Desc:    backup dbName db data   
  5.   
  6. mysqlserver='127.0.0.1'  
  7. mysqldbname='dbName'   #数据库名  
  8. mysqluser='dbName'     #数据库用户名  
  9. mysqlpwd='dbPassword'  #数据库密码  
  10. mysqlbakdir='/usr/java/bak_msyql'   #数据库备份目录  
  11. if [ ! -d '$mysqlbakdir/`date +%Y`/`date +%m`' ];then  
  12.    mkdir -p $mysqlbakdir/`date +%Y`/`date +%m`  
  13. fi  
  14. sqlbakfile=$mysqlbakdir/`date +%Y`/`date +%m`/$mysqldbname`date +%F-%H-%M-%S`.sql  
  15.   
  16. mysqldump -u$mysqluser -p$mysqlpwd   -h$mysqlserver --hex-blob $mysqldbname >$sqlbakfile  
  17. tar czvPf $sqlbakfile.tar.gz $sqlbakfile  
  18. rm $sqlbakfile  

给 bak_mysql.sh 执行权限

# chmod u+x bak_mysql.sh

先执行一下看看脚本是否成功?

# ./bak_mysql.sh 

查看备份文件是否生成?
# cd /usr/java/bak_msyql
# ll

没有生成,那说明 bak_msyql.sql 脚本有问题,自行调试到正确为止.


添加计划任务


# crontab -e

这个时候操作跟 vim 一样.

输入:

0 4 * * * /usr/java/shell/bak_mysql.sh

保存.(上面这个是每天凌晨4点执行一次)

启动定时任务.
# /sbin/service crond start

查看crontab日志:
# tail -f /var/log/cron

把 crontab 设置为开机时自动运行
在/etc/rc.d/rc.local这个脚本的末尾加上 /sbin/service crond start 


其他说明

crontab -u //设定某个用户的cron服务,一般root用户在执行这个命令的时候需要此参数

crontab -l //列出某个用户cron服务的详细内容

crontab -r //删除没个用户的cron服务

crontab -e //编辑某个用户的cron服务

/sbin/service crond start //启动服务 
/sbin/service crond stop //关闭服务 
/sbin/service crond restart //重启服务 
/sbin/service crond reload //重新载入配置 
/sbin/service crond status //查看状态

或者使用

# service crond start 
# service crond stop 
# service crond restart 
# service crond reload 
# service crond status

定时参数说明


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字段,表示每十分钟执行一次。


参考博客

http://blog.csdn.net/testcs_dn/article/details/48829785
http://www.cnblogs.com/chen-lhx/p/5996781.html
http://blog.csdn.net/testcs_dn/article/details/48780971

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: #!/bin/bash # 备份MySQL数据库 # 设置变量 MYSQL_USER="root" MYSQL_PASS="password" DATABASE="database_name" BACKUP_DIR="/path/to/backup/dir" DATE=$(date +"%Y-%m-%d") # 创建备份文件夹 mkdir -p "$BACKUP_DIR/$DATE" # 备份数据库 mysqldump -u $MYSQL_USER -p$MYSQL_PASS $DATABASE > "$BACKUP_DIR/$DATE/$DATABASE.sql" ### 回答2: 编写一个用于备份MySQL数据库Shell脚本可以按照以下步骤进行: 1. 首先,创建一个Shell脚本的文件,比如命名为`backup_mysql.sh`。 2. 在脚本中,使用`#!/bin/bash`指定脚本解释器为bash。 3. 声明配置变量,如数据库用户名、密码、数据库主机等。 ```bash #!/bin/bash # 配置数据库信息 DB_USER="your_db_username" DB_PASSWORD="your_db_password" DB_HOST="your_db_host" DB_NAME="your_db_name" # 指定备份文件名和路径 BACKUP_DIR="/path/to/backup_directory" CURRENT_DATE=$(date +"%Y%m%d") BACKUP_FILE="$BACKUP_DIR/backup_$CURRENT_DATE.sql" ``` 4. 使用mysqldump命令备份数据库并保存到指定目录下的备份文件。 ```bash # 使用mysqldump命令备份数据库到指定备份文件 mysqldump -h $DB_HOST -u $DB_USER -p$DB_PASSWORD $DB_NAME > $BACKUP_FILE ``` 5. 判断备份是否成功,并输出相应的提示信息。 ```bash # 判断备份是否成功 if [ $? -eq 0 ] then echo "数据库备份成功!" else echo "数据库备份失败!" fi ``` 6. 添加执行权限。在脚本所在目录中执行`chmod +x backup_mysql.sh`命令,给脚本添加执行权限。 7. 运行脚本。在终端中切换到脚本所在的目录,并执行`./backup_mysql.sh`命令。 注意:在上述代码中,你需要根据你自己的MySQL数据库配置信息来修改相应的变量值,以确保脚本能够正确备份数据库。 ### 回答3: 编写一个shell脚本用于备份MySQL数据库是一项常见的任务。下面是一个简单的示例脚本: #!/bin/bash # 定义数据库相关信息 DB_USER="your_username" DB_PASSWORD="your_password" DB_NAME="your_database_name" BACKUP_DIR="/path/to/backup_directory" # 创建备份目录 mkdir -p $BACKUP_DIR # 定义备份文件名 BACKUP_FILE="${BACKUP_DIR}/${DB_NAME}_$(date +%Y%m%d%H%M%S).sql" # 使用mysqldump命令备份数据库 mysqldump -u $DB_USER -p$DB_PASSWORD $DB_NAME > $BACKUP_FILE # 检查备份是否成功 if [ $? -eq 0 ]; then echo "数据库备份成功!备份文件:$BACKUP_FILE" else echo "数据库备份失败!" fi 脚本中定义了数据库的用户名、密码和名称,以及备份存储的目录。脚本使用mysqldump命令来执行实际的备份操作,并将备份文件命名为当前日期和时间。最后,脚本通过检查mysqldump命令的退出码来确定备份是否成功,并输出相应的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值