├── Web_backup.sh ├── Mysql_backup.sh └── Readme.md /Web_backup.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | #自动备份脚本 3 | 4 | #定义所需变量 5 | WEB_PATH="/var/www/html/" #需要备份的网站目录 6 | BAKE_PATH="/opt" #备份后存放目录 7 | LOG_PATH="/var/apache_backup.log" #备份日志存放目录及日志名称 8 | filename="`date '+%F'`-apache.tar.gz" #备份存放文件名称 9 | to_file="$BAKE_PATH/$filename" 10 | #备份失败退出 11 | ERR_QUIT=1 12 | 13 | #自动删除删除超期文件 14 | #保留30多少天前的文件 15 | OVERTIME=30 16 | #删除超期文件 17 | find $BAKE_PATH -ctime +$OVERTIME -a -name "*apache.tar.gz" -exec rm -f {} \; 18 | if [ $? -eq 0 ];then 19 | echo -e "`date '+%F-%M-%S'`\t删除过期文件成功">>$LOG_PATH 20 | #调试时输出日志信息 21 | # tail -1 $LOG_PATH 22 | fi 23 | 24 | #进行备份操作 25 | tar zcf $to_file $WEB_PATH &> /dev/null 26 | #echo $? 27 | 28 | #判断是否备份成功 29 | if [ $? -eq 0 ]; then 30 | echo -e "`date '+%F-%M-%S'`\t备份成功">>$LOG_PATH 31 | else 32 | echo -e "`date '+%F-%M-%S'`\t备份失败">>$LOG_PATH 33 | 34 | exit $ERR_QUIT 35 | fi 36 | 37 | #空间占用百分比 38 | percent=$(df $BAKE_PATH |awk '/dev/{print $5}') 39 | echo -e "当前空间的占用百分比:$percent">>$LOG_PATH 40 | #输出日志信息 41 | tail -2 $LOG_PATH 42 | -------------------------------------------------------------------------------- /Mysql_backup.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | #自动备份脚本 3 | 4 | #定义所需变量 5 | BAKE_PATH="/opt" #备份后存放目录 6 | LOG_PATH="/var/myql_backup.log" #备份日志存放目录及日志名称 7 | filename="`date '+%F'`_DatabaseName.tar.gz" #备份存放文件名称 8 | to_file="$BAKE_PATH/$filename" 9 | 10 | #备份失败退出 11 | ERR_QUIT=1 12 | 13 | #自动删除删除超期文件 14 | #保留30多少天的文件 15 | OVERTIME=30 16 | #删除超期文件 17 | find $BAKE_PATH -ctime +$OVERTIME -a -name "*DatabaseName.tar.gz" -exec rm -f {} \; 18 | if [ $? -eq 0 ];then 19 | echo -e "`date '+%F-%M-%S'`\t删除过期文件成功">>$LOG_PATH 20 | #调试时输出日志信息 21 | # tail -1 $LOG_PATH 22 | fi 23 | 24 | #进行备份操作 25 | mysqldump -uusername -ppassword DatabaseName > $BAKE_PATH/"`date '+%F'`_DatabaseName.sql" 26 | #将生成的SQL文件压缩 27 | tar zcf $to_file $BAKE_PATH/"`date '+%F'`_DatabaseName.sql" &> /dev/null 28 | #echo $? 29 | 30 | #判断是否备份成功 31 | if [ $? -eq 0 ]; then 32 | echo -e "`date '+%F-%M-%S'`\t备份成功">>$LOG_PATH 33 | #备份成功删除生成的SQL文件,保留压缩包 34 | rm -rf $basepath/*.sql 35 | else 36 | echo -e "`date '+%F-%M-%S'`\t备份失败">>$LOG_PATH 37 | 38 | exit $ERR_QUIT 39 | fi 40 | 41 | #空间占用百分比 42 | percent=$(df $BAKE_PATH |awk '/dev/{print $5}') 43 | echo -e "当前空间的占用百分比:$percent">>$LOG_PATH 44 | #输出日志信息 45 | tail -2 $LOG_PATH 46 | -------------------------------------------------------------------------------- /Readme.md: -------------------------------------------------------------------------------- 1 | **注意:** 2 | 3 | 1. Mysql_backup.sh 为 mysql 自动备份 脚本,配合 crontab命令 用来管理需要周期性执行任务 4 | 2. Web_backup.sh 为 web文件 自动备份 脚本,配合 crontab命令 用来管理需要周期性执行任务 5 | 6 | ``` 7 | Mysql_backup.sh 里: 8 | 9 | * 把 username 替换为mysql的用户名; 10 | * 把 password 替换为mysql的密码; 11 | * 把 DatabaseName 替换为需要备份的数据库名; 12 | 13 | ``` 14 | 15 | 使用时添加可执行权限: 16 | ``` 17 | chmod u+x Mysql_backup.sh 18 | ``` 19 | 或 20 | ``` 21 | chmod u+x Web_backup.sh 22 | ``` 23 | 24 | 此脚本利用mysqldump命令,mysqldump命令是mysql数据库中备份工具,用于将MySQL服务器中的数据库以标准的sql语言的方式导出,并保存到文件中。配合 crontab命令 实现自动备份。 25 | 26 | 27 | ## 知识扩展 28 | 29 | 30 | ### mysqldump(选项) 31 | ``` 32 | --add-drop-table:在每个创建数据库表语句前添加删除数据库表的语句; 33 | --add-locks:备份数据库表时锁定数据库表; 34 | --all-databases:备份MySQL服务器上的所有数据库; 35 | --comments:添加注释信息; 36 | --compact:压缩模式,产生更少的输出; 37 | --complete-insert:输出完成的插入语句; 38 | --databases:指定要备份的数据库; 39 | --default-character-set:指定默认字符集; 40 | --force:当出现错误时仍然继续备份操作; 41 | --host:指定要备份数据库的服务器; 42 | --lock-tables:备份前,锁定所有数据库表; 43 | --no-create-db:禁止生成创建数据库语句; 44 | --no-create-info:禁止生成创建数据库库表语句; 45 | --password:连接MySQL服务器的密码; 46 | --port:MySQL服务器的端口号; 47 | --user:连接MySQL服务器的用户名。 48 | 49 | ``` 50 | **实例** 51 | 52 | **导出整个数据库** 53 | ``` 54 | 语法: 55 | mysqldump -u 用户名 -p 数据库名 > 导出的文件名 56 | 例: 57 | mysqldump -u linuxde -p apps_linux > linux.sql 58 | 59 | ``` 60 | **导出一个表** 61 | ``` 62 | 语法: 63 | mysqldump -u 用户名 -p 数据库名 表名 > 导出的文件名 64 | 例: 65 | mysqldump -u linuxde -p apps_linux users > linux_users.sql 66 | ``` 67 | **导出一个数据库结构** 68 | ``` 69 | 例: 70 | mysqldump -u linuxde -p -d --add-drop-table apps_linux > linux_db.sqle_db.sql 71 | ``` 72 | 73 | ## crontab(选项)(参数) 74 | 75 | crontab文件:指定包含待执行任务的crontab文件,选项: 76 | ``` 77 | -e:编辑该用户的计时器设置; 78 | -l:列出该用户的计时器设置; 79 | -r:删除该用户的计时器设置; 80 | -u<用户名称>:指定要设定计时器的用户名称。 81 | ``` 82 | 用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下: 83 | ``` 84 | minute hour day month week command 顺序:分 时 日 月 周 85 | ``` 86 | 其中: 87 | ``` 88 | minute: 表示分钟,可以是从0到59之间的任何整数。 89 | hour:表示小时,可以是从0到23之间的任何整数。 90 | day:表示日期,可以是从1到31之间的任何整数。 91 | month:表示月份,可以是从1到12之间的任何整数。 92 | week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。 93 | command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。 94 | ``` 95 | 在以上各个字段中,还可以使用以下特殊字符: 96 | 97 | * 星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。 98 | * 逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9” 99 | * 中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6” 100 | * 正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。 101 | 102 | **实例** 103 | 104 | 每1分钟执行一次command 105 | ``` 106 | * * * * * command 107 | ``` 108 | 109 | 每小时的第3和第15分钟执行 110 | ``` 111 | 3,15 * * * * command 112 | ``` 113 | 114 | 请结合实际修改shell即可使用~ 115 | --------------------------------------------------------------------------------