当前位置:Gxlcms > 数据库问题 > Mysql 自动备份脚本

Mysql 自动备份脚本

时间:2021-07-01 10:21:17 帮助过:2人阅读

  •   
  • mysql>grant select,lock tables on yyyy.*to ‘kanghui‘@‘192.168.10.11‘ identified by ‘123456‘;  
  •  设置访问权限后就在备份服务器上测试数据库访问,查询授权等是否有效。

    Java代码  技术分享
    1. [root@localhost ~]#mysqldump -u root -p123456 -h 192.168.10.22 --databases xxxx > ceshi.sql  
    2.   
    3. [root@localhost ~]#ls -lh ceshi.sql  

     

    下面是一个mysql的备份脚本,根据自己的需求修改即可。

    Java代码  技术分享
    1. [root@localhost ~]#mkdir -p /opt/mysql_bak/  
    2. [root@localhost ~]#cd /opt/mysql_bak/  
    3. [root@localhost mysql_bak]# vim mysql_bak.sh  
    4. #!/bin/bash  
    5. #auto backup mysqldb  
    6. #by authors kanghui 2016-06-12  
    7. #这是一个简单化到MYSQL数据库逻辑备份脚本  
    8. #1.定义数据库链接,目标库信息  
    9. MY_user="root"  
    10. MY_pass="123456"  
    11. MY_host="192.168.10.22"  
    12. MY_conn="-u $MY_user -p$MY_pass -h $MY_host"  
    13. MY_db1="xxxx"  
    14. MY_db2="yyyy"  
    15. #2.定义备份目录,工具,时间,文件名  
    16. BF_dir="/opt/mysql_bak"  
    17. BF_cmd="/usr/bin/mysqldump"  
    18. BF_time="date +%Y%m%d-%H%M"  
    19. name_1="$MY_db1-$BF_time"  
    20. name_2="$MY_db2-$Bf_time"  
    21. #3先导出为.sql脚本,然后再进行压缩(打包后删除源文件)  
    22. cd $BF_dir  
    23. $BF_cmd $MY_conn --databases $MY_db1 > $name_1.sql  
    24. $BF_cmd $MY_conn --databases $MY_db2 > $name_2.sql  
    25. /bin/tar zcf $name_1.tar.gz $name_1.sql --remove &> /dev/null  
    26. /bin/tar zcf $name_2.tar.gz $name_2.sql --remove &> /dev/null  

    设置权限并测试:

    Java代码  技术分享
    1. [root@localhost mysql_bak]#chmod +x mysql_bak.sh  
    2.   
    3. [root@localhost mysql_bak]#./mysql_bak.sh  
    4.   
    5. [root@localhost mysql_bak]#ls -lh /opt/mysql_bak/*.gz  

     

     最后把脚本加入带计划任务即可。

    Java代码  技术分享
    1. [root@localhost ~]#crontab -e  
    2. 30 2 * * * /opt/mysql_bak/mysql_bak.sh 

    Mysql 自动备份脚本

    标签:

    人气教程排行