转自

Mysql 自动备份脚本2 - - ITeye技术网站
http://kangh.iteye.com/blog/2309091

备份方案:

备份主机:192.168.10.11

数据库服务器:192.168.10.22

备份内容:对mysql服务器中的xxxx和yyyy库进行远程备份,每天凌晨2:30执行,每个库备份为独立的.sql文件,然后压缩成.tar.gz的格式,文件名中嵌入执行备份的日期和时刻。

工作准备:

1、确保备份主机与数据库服务器之间的网络保持连接通畅,不能有网络链路故障,防火墙等阻碍。

2、mysql服务必须允许备份主机远程访问,且授权用户能够查询xxxx和yyyy库。

这儿可以创建一个专用的数据库备份账户"kanghui" 允许备份主机192.168.10.11连接到mysql数据库,并授权对xxxx和yyyy库的读取权限,使用逻辑备份工具mysqldump的时候,需要对库设置select和lock和tables权限。

  1. mysql>grant select,lock tables on xxxx.*to 'kanghui'@'192.168.10.11' identified by '123456';
  2. mysql>grant select,lock tables on yyyy.*to 'kanghui'@'192.168.10.11' identified by '123456';

设置访问权限后就在备份服务器上测试数据库访问,查询授权等是否有效。

  1. [root@localhost ~]#mysqldump -u root -p123456 -h 192.168.10.22 --databases xxxx > ceshi.sql
  2. [root@localhost ~]#ls -lh ceshi.sql

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

  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

设置权限并测试:

  1. [root@localhost mysql_bak]#chmod +x mysql_bak.sh
  2. [root@localhost mysql_bak]#./mysql_bak.sh
  3. [root@localhost mysql_bak]#ls -lh /opt/mysql_bak/*.gz

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

  1. [root@localhost ~]#crontab -e
  2. 30 2 * * * /opt/mysql_bak/mysql_bak.sh

Mysql 自动备份脚本的更多相关文章

  1. python编写Mysql自动备份脚本

    1、先写一个python脚本 vim /opt/mysql_dump.py #!/usr/bin/env python# -*- coding:utf-8 -*-import osimport tim ...

  2. linux系统中mysql自动备份脚本

    mysql数据库中存储着网站最核心最宝贵的数据,如果因为不可预测的原因导致数据损坏或丢失,对一个网站的打击是毁灭性的,一次又一次的教训提醒着我们一定要做好备份,但是手工备份确实比较麻烦,每天都要手工操 ...

  3. mysql自动备份脚本

    linux系统mysql5.6版本实现自动备份步骤 1.sudo mysql --help | grep my.cnf 查找my.cnf文件2.在文件中添加如下行实现免输入密码[mysqldump]u ...

  4. ubuntu server 11.10 mysql 自动备份脚本

    1.下载最新的备份脚本(AutoMySQLBackup) 点这里下载 2.修改脚本配置部分 vi  /root/automysqlbackup-2.5.1-01.sh USERNAME=root PA ...

  5. linux下mysql自动备份脚本

    脚本放在 /home/user/mysql_backup.sh crontab # crontab -l # m h  dom mon dow   command 28 16 * * * /home/ ...

  6. Linux 下Mysql自动备份脚本

    backdb.sh 文件 #!/bin/bash USER="root" PASSWORD="888888" DATABASE="mydb" ...

  7. mysql 自动备份和nginx自动安装脚本

    一.自动备份Mysql脚本: 如下脚本为mysql自动备份脚本,仅供参考,可以根据实际情况修改. #!/bin/sh #auto backup mysql #wugk #Define PATH定义变量 ...

  8. MySql自动备份shell

    MySql黑屏备份是每个运维工程师必备的技能,以下是MySQL自动备份脚本: #/bin/bash#This is mysql backup shell on 2019/4/28 BAKUP_DIR= ...

  9. MySQL binlog 自动备份脚本

    MySQL binlog 自动备份脚本 1 利用shell进行备份 #!/bin/sh #mysql binlog backup script /usr/local/mysql/bin/mysqlad ...

随机推荐

  1. 使用纯css3实现图片轮播

    <!DOCTYPE html> <html> <head> <title> 飛天网事--纯CSS代码实现图片轮播 </title> < ...

  2. iOS开发之 用第三方类库实现ScrollView

    转自:http://www.cnblogs.com/qianLL/p/5369127.html   在github上面有很多的第三方类库,大大节约了大家的开发时间 下载地址:https://githu ...

  3. Linux下wps字体问题

    1.安装symbol-fonts_1.2_all.deb,自行搜索 2.卸载xfonts-mathml字体 sudo apt-get remove xfonts-mathml

  4. php fsockopen例子

    <?php /* * 短信相关api */ class Webcall { protected $VCC_CODE; //api的账号 protected $password; //api的密码 ...

  5. HADOOP与ORACLE关联

    安装Oracle和Oracle大数据连接器/OLH,尝试把HDFS中的数据文件装载到Oracle中的表 http://f.dataguru.cn/thread-460110-1-1.html 文档讲述 ...

  6. android 实践项目

    电子词典  http://files.cnblogs.com/blogLYF/lyf_danci.apk

  7. ios给textView提价提示性文字

    不推荐使用的方式 但是在用的时候才发现原来textView没有类似于textField的那种placeholder功能.所谓placeholder就比如用户看到一个输入框,然后输入框里面一般会有几个浅 ...

  8. iosOC/C不可变数组排序

    //1.回顾C数组排序 int a[6] = {1,4,3,5,6,2}; //选择 for (int i =0; i<6-1; i++) { for (int j = i+1; j<6; ...

  9. 使用putty上传文件到linux系统

    使用window的cmd命令 上传文件到linux  使用putty下的 pscp.exe pscp -r -l root -pw 1234567890 e:/htk 192.168.0.204:/r ...

  10. C++之文件输入输出

    在这里遇见不少的问题,其中的路径问题就是在windows中,\\转义字符才能准确的表示路径 #include <iostream> #include <fstream> #in ...