编辑
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=0for file in $fileListdo iCounter=`expr $iCounter + 1 ` echo ${file}done
nextNum=0for file in $fileListdo 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 -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 fidone
-h${db_host}
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- oldu.cn 版权所有 浙ICP备2024123271号-1
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务