我们通常使用原生的mysql会比较多,mysql的备份也耳熟能详。假如现在有个mysql数据库username为root,password为123456,且现在要导出schema为db1、db2的数据。
在本地导出的时候我们可以通过
mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql
将schema为db1、db2的数据导出到路径为/data_backup/xxx.sql的文件中。
但是若mysql为docker镜像的时候应该怎样进行导出呢?
很多同学也许会想着使用
docker exec -it $container_name mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql
进行导出。但是会发现直接使用上面语句导出是可以得到xxx.sql的数据备份的,但是如果将语句放在定时器上执行却是得到一个为空的xxx.sql文件。
究竟是为什么呢?
通常我们意识里会认为能够执行的语句或者脚本也可以通过定时器去执行,定时器只是做一个触发的动作而已。
是的,的确没有错,但是问题就在于如何触发执行里。
当我们手动执行的时候是通过docker exec -it去创建一个伪终端去执行mysqldump的,所以是可行的。
但是在定时器自动触发的时候本来就是在终端里面,因此是不需要通过-it进行伪终端的创建的,因为后者是没有宿主机的环境变量的,因此会报错。
所以正确的命令为:
docker exec -i $container_name mysqldump -uroot -p123456 --databases db1 db2 > /data_backup/xxx.sql
把t去掉就可以了。
标签:mysql,备份,xxx,导出,sql,db1,Docker,db2,MySQL From: https://blog.51cto.com/u_15761576/6050902