1.在 /etc/my.cnf 下面設置開啟bin-log
編輯
vim /etc/my.cnf
[mysqld]
binlog_format = MIXED //binlog日志格式
log_bin =目錄/mysql-bin.log //binlog日志名
expire_logs_days = 7 //binlog過期清理時間
#max_binlog_size 100m //binlog每個日志文件大小 最大值和默認是1個G
binlog-do-db=game #需要備份的數據庫名,如果備份多個數據庫,重復設置這個選項即可
binlog-do-db=platform #
#binlog-ignore-db=不需要備份的數據庫,如果備份多個數據庫,重復設置這個選項即可
2.創建遠程登陸數據庫帳號
grant all privileges on game.* to 'jack'@'192.168.10.56' identified by 'admin'
grant all privileges on platform.* to 'jack'@'192.168.10.56' identified by 'admin'
3.將服務器上的數據,導入一份進遠程服務器中
mysqldump -ujack -padmin -h192.168.10.38 > 備份數據庫地址(/home/mysql/db/mysql.sql);
4.寫Linux 計划任務:
vim /etc/crontab
在底部加入
0 3 * * * root sh /home/wwwroot/sh/mysqlbackup.sh #每天3點以root帳號的權限執行目錄下的sh
重啟服務
/etc/init.d/crond restart
---------------------------------------------------
如果遇到了問題,請查看一下
select super_priv,user from user where host='192.168.10.39';
update user set super_priv='Y' where user='game1';
#! /bin/Bash ################## # 2013-9-24 # # author jackluo # ################## db_user= #遠程mysql用戶名 db_pwd= #遠程mysql密碼 db_host= #遠程ip mysql_bin=/usr/local/mysql/bin/ #mysql 執行【招待】目錄 mysqlbindir=/usr/local/mysql/var/ #binlog日志存放目錄 dailyBackupDir=/root/mysql/ #存放,導入成功的日志 binlogname="mysql-bin" #binlog日志前綴 cd $mysqlbindir fileList=`cat mysql-bin.index` iCounter=0 for file in $fileList do iCounter=`expr $iCounter + 1 ` echo ${file} done nextNum=0 for file in $fileList do binLogName=`basename $file ` nextNum=`expr $nextNum + 1 ` if [[ $nextNum == $iCounter ]]; then echo "Skip lastest!" > /dev/null else dest=$dailyBackupDir/$binLogName if [[ -e $dest ]]; then #檢查是否已導入過了 echo "Skip exist $binLogName!" > /dev/null else ${mysql_bin}mysqlbinlog $binLogName|mysql -h${db_host} -u${db_user} -p${db_pwd} #寫入遠程數據庫 if [[ ! -d ${dailyBackupDir} ]];then mkdir -p ${dailyBackupDir} fi touch ${dest} #創建日志文件 find . -type f -ctime +6 -exec rm {} \; #刪除6天后的日志文件 fi fi done