crontab 添加计划任务执行docker exec命令

in mysqldocker with 0 comment

同事写了个备份mysql容器的脚本,手动执行没问题,放到计划任务就备份文件大小为0.怎么都不行。
CentOS6.x 64位系统。

1.脚本如下

cat sqlbak.sh
#!/bin/bash
source /etc/profile

/usr/bin/docker exec -it windranger_some_mysql_1 mysqldump -h '127.0.0.1' -uroot -p'root' windranger > /root/mysqlbak/`date  "+%Y-%m-%d~%H-%M-%S"`.sql

2.计划任务如下

crontab -l
* * * * * /bin/bash/ root/sqlbak.sh

解决方法:
谷歌搜索结果(百度搜了许久,没个靠谱的答案):
Your docker exec command says it needs "pseudo terminal and runs in interactive mode" (-it flags) while cron doesn't attach to any TTYs.

大致意思 exec 加了 -it 参数就开启了一个终端,计划任务是无法进入任何终端的。

修改后的正确脚本如下:

#!/bin/bash
source /etc/profile

/usr/bin/docker exec windranger_some_mysql_1 /usr/bin/mysqldump -h '127.0.0.1' -uroot -p'root' windranger > /root/mysqlbak/`date  "+%Y-%m-%d~%H-%M-%S"`.sql

查看备份目录:

ls /root/mysqlbak
total 3116
-rw-r--r--. 1 root root 166329 Jul  6 11:50 2018-07-06~11-50-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:51 2018-07-06~11-51-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:52 2018-07-06~11-52-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:53 2018-07-06~11-53-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:54 2018-07-06~11-54-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:55 2018-07-06~11-55-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:56 2018-07-06~11-56-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:57 2018-07-06~11-57-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:58 2018-07-06~11-58-01.sql
-rw-r--r--. 1 root root 166329 Jul  6 11:59 2018-07-06~11-59-01.sql
Responses