运维小东西:每天备份sql到远程服务器上

时间:2022-08-08 04:49:40

  首先两台服务器可以无密码登录(这个方式比较简单,当然安全系数会降低)

#ssh-keygen -t rsa
#生成密钥发送给远程服务器上
#ssh-copy-id ~/root/id_rsa.pub user@host

  这样ssh的时候就不用输入密码了。对于crontab这种定时自动运行的任务来说还是比较方便的。

  现在就是写shell备份sql到远程服务器的脚本:

#!/bin/sh
DB_NAME1=""
DB_USER=""
DB_PASS="" BCK_DIR="/root/backup"
DATE=`date +%F` mysqldump -u$DB_USER $DB_NAME1 > $BCK_DIR/db_"$DB_NAME1"_"$DATE".sql NAME1=$BCK_DIR/db_"$DB_NAME1"_"$DATE".sql
scp $NAME1 root@172.16.253.120:/home/rainsun/backup
rm -rf $NAME1

然后就是crontab -e写定时,这里对crontab的格式做简单的说明:

Crontab 格式说明
我们可以用crontab -e 添加要执行的命令。 命令执行的结果,无论是标准输出还是错误输出,都将以邮件形式发给用户。

添加的命令必须以如下格式:
* * * * * /command path

前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。

前5个字段分别表示:
分钟:0-59
小时:1-23
日期:1-31
月份:1-12
星期:0-6(0表示周日)

还可以用一些特殊符号:
*: 表示任何时刻
,: 表示分割
  -:表示一个段,如第二端里: 1-5,就表示1到5点
/n : 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1.

一些示例:
00 8,12,16 * * * /data/app/scripts/monitor/df.sh
30 2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh
10 8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh

43 21 * * * 21:43 执行
15 05 * * *    05:15 执行
0 17 * * * 17:00 执行
0 17 * * 1 每周一的 17:00 执行
0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行
0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行
0 0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行
42 4 1 * *     毎月1日的 4:42分 执行
0 21 * * 1-6   周一到周六 21:00 执行
0,10,20,30,40,50 * * * * 每隔10分 执行
*/10 * * * *        每隔10分 执行
* 1 * * *         从1:0到1:59 每隔1分钟 执行
0 1 * * *         1:00 执行
0 */1 * * *        毎时0分 每隔1小时 执行
0 * * * *         毎时0分 每隔1小时 执行
2 8-20/3 * * *      8:02,11:02,14:02,17:02,20:02 执行
30 5 1,15 * *       1日 和 15日的 5:30 执行

至于具体怎么写crontab视你任务的重要性而定