mysql主从配置,innobackup备份

目的:19 作为 20 的从库

20上做一次全备份

/usr/bin/innobackupex-1.5.1--user=root --password=`cat /etc/savep` --defaults-file=/etc/my.cnf --socket=/tmp/mysql.sock  --slave-info--stream=tar /usr/local/backup | gzip >/usr/local/backup/db20.tar.gz

db20.tar.gz copy 19

--slave-info 保存主库日志文件以及偏移

--stream=tar/usr/local/backup | gzip > /usr/local…压缩方式

[ 在使用参数stream=tar备份的时候,你的xtrabackup_logfile可能会临时放在/tmp目录下,多实例 xtrabackup在备份的时候会生成固定文件/tmp/xtrabackup_logifle,导致互相覆盖。 --tmpdir= ]

19上启动新的实例

  1. 新建/etc/myNew.cnf 注意server id 要跟20不一样 my.cnf server_id xxx
  2. 初始化数据库

3.           scripts/mysql_install_db --user=mysql --datadir=/data/mysqlNew/dataNew  --basedir=/usr/local/mysql

  1. 启动新的实例待会用于做从库

5.           /usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/myNew.cnf --user=mysql &

19上安装 xtrabackup

旧版本5.1

wgethttp://115.182.52.17/software/xtrabackup-1.6.5-328.rhel6.x86_64.rpm

rpm -ivh xtrabackup-1.6.5-328.rhel6.x86_64.rpm  --nodeps (rpm方式安装xtrabackup.)

新版本5.6

wget -O/root/soft/percona-xtrabackup-2.2.11-1.el6.x86_64.rpm

http://115.182.52.17/software/percona-xtrabackup-2.2.11-1.el6.x86_64.rpm

rpm -ivh percona-xtrabackup-2.2.11-1.el6.x86_64.rpm  --nodeps

19上恢复主库的冷备份数据

  1. 解压

2.           mv db20.tar.gz /usr/local/backup/

3.           tar -izxvf db20.tar.gz

这里tar解包必须使用-i参数,否则解压出来的文件只有一个backup-my.cnf

  1. 一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处理不一致状态。--apply-log的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。

5.           innobackupex --apply-log . --user=root --password=`cat /etc/savep(不存在密码就不需要这个项)` --defaults-file=/etc/myNew.cnf

  1. 拷贝数据文件

7.           mysqladmin -uroot -S /tmp/mysqlNew.sock shutdown –p 停库删除

8.           cd /data/mysqlNew/dataNew/

9.           rm -rf *

10.       mv /usr/local/backup/* .

11.       chown -R mysql.mysql *

12.       mysqld_safe  --defaults-file=/etc/myNew.cnf --user=mysql &

tail -f log.err 查看是否有报错

进数据库查看数据库是否跟主库一样,

至此已经把20的数据库冷备份恢复到19了

启动同步

  1. 确定主库冷备份的的binlog位置

2.           cd /data/mysqlNew/dataNew/

3.           cat xtrabackup_binlog_info  (如果冷备份是从主库直接备份的,则使用这个来确定主库的binlog位置)

4.           或者catxtrabackup_slave_info (如果冷备份是从主库的另外一个从库简介备份的,则使用这个来确定主库的binlog位置)

  1. 进入新实例,新建同步

6.           mysql -uroot -S /tmp/mysqlNew.sock -p

7.           mysql>change master to

8.           -> master_host=‘10.0.0.20‘,

9.           ->master_user=‘re4399pl‘,

10.       ->master_port=3306,

11.       ->master_password=‘re4399plpassword‘,

12.       ->master_log_file=‘mysql-bin.000006‘,

13.       ->master_log_pos=110632233;

上面这步需要现在主库上创建帐号

GRANT FILE,SELECT,REPLICATION SLAVE ON*.* TO ‘re4399pl‘@‘10.0.0.%‘IDENTIFIED BY ‘re4399plpassword‘;

master_log_filemaster_log_pos 就是五.1 中的内容

  1. 启动同步

15.       mysql>start slave;

16.       mysql> show slave status\G

17.       如果要重启库,

18.         1,mysqladmin –uroot –pxxxx   2,mysqld_safe –user=mysql

其他注意点

  1. 注意多个实例的下的不同data目录和 my.cnf 文件
  2. 从库是不记录Binlog的如果需要做链式同步,从库开启binlog :log_slave_updates=1
  3. skip-slave-start 有这个参数,数据库重启后不会自动进行同步
  4. 主从废弃后,应该及时 stop slave 并 reset slave 免得忘记下次又同步

关于同步到从库并过滤部分表的做法

在从库上添加

replicate-wild-do-table=diygame_admin.%

replicate-wild-ignore-table=diygame_online.diygame_game_data%

replicate-wild-do-table=diygame_online.%

同步后重定向到另外一个库

在从库上添加

replicate-wild-do-table=diygame_admin.diygame_template_preview

replicate-wild-do-table=3387_base_admin.%

replicate-rewrite-db=diygame_admin->3387_base_admin

replicate-rewrite-db,及仅能重定向库,不能重定向表,而且还does not workwith cross-database updates

时间: 2024-10-29 19:09:51

mysql主从配置,innobackup备份的相关文章

mysql主从配置&&基于keepalived的主备切换

mysql互为主从设置 && 主备切换配置 需求说明: 1.公司架构一直是一台单独的mysql在线上跑,虽然一直没有出现什么宕机事件,但是出于一个高可用的考虑,提出主从备份.主备切换的需求: 2.实现这个需求的前一段时间只是在做数据库备份的时候实现了主从热备,为了实现主备切换功能,继续操作上述需求: 实验环境: master1:10.1.156.3:3306 master2:10.1.156.5:3306 my.cnf配置文件关于主从这块的修改: master1: server-id =

解读mysql主从配置及其原理分析(Master-Slave)

在windows下配置的,后面会在Linux下配置进行测试,需要配置mysql数据库同步的朋友可以参考下. 1.在主数据库服务器为从服务器添加一个拥有权限访问主库的用户:GRANT REPLICATION SLAVE ON *.* TO ' test'@'%' IDENTIFIED BY 'test'; (%表示允许所有IP,可设置指定从服务器IP)添加用户后:可在从服务器上用mysql -h127.0.0.1 -utest -ptest; 来测试是否有权限访问主数据库 2.在主据库配置文件加上

Linux下mysql主从配置

mysql服务器的主从配置,这样可以实现读写分离,也可以在主库挂掉后从备用库中恢复需要两台机器,安装mysql,两台机器要在相通的局域网内主机A: 192.168.1.100从机B:192.168.1.101可以有多台从机1.先登录主机 Amysql>GRANT REPLICATION SLAVE ON *.* TO ‘backup’@’192.168.1.101‘ IDENTIFIED BY ‘123456’;赋予从机权限,有多台丛机,就执行多次2. 打开主机A的my.cnf,输入server

Mysql笔记之 -- 小试MYSQL主从配置

mysql主从配置: 硬件: 两台服务器 1.Ubuntu 12.04.4 LTS (GNU/Linux 3.2.0-60-generic-pae i686) 2.Ubuntu 12.04.4 LTS (GNU/Linux 3.2.0-60-generic-pae i686) 分别安装mysq mysql Ver 14.14 Distrib 5.5.35, for debian-linux-gnu (i686) using readline 6.2 主服务器(192.168.1.101,root

8.31 MySQL主从配置、准备工作、配置主、配置从、测试主从同步

1.MySQL主从配置  MySQL主从又叫做Replication.AB复制.简单讲就是A和B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,两者数据是实时同步的 MySQL主从是基于binlog的,主上须开启binlog才能进行主从. 主从过程大致有3个步骤 1)主将更改操作记录到binlog里 2)从将主的binlog事件(sql语句)同步到从本机上并记录在relaylog里 3)从根据relaylog里面的sql语句按顺序执行 主上有一个log dump线程,用来和从的I/O线

mysql主从配置实现一主一从读写分离

主从介绍 定义 Mysql主从又叫Replication.AB复制.简单讲就是A与B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,实现数据实时同步 mysql主从是基于binlog,主上需开启binlog才能进行主从 主从过程大概有3个步骤 主将更改操作记录到binlog里 从将主的binlog事件(sql语句) 同步本机上并记录在relaylog里 从根据relaylog里面的sql语句按顺序执行 主上有一个log dump线程,用来和从的I/O 线程传递binlog 从上有两个线

Mysql主从配置实战

实战mysql主从配置 准备两个docker容器,分别在3306和3307开启两个mysql为主从数据库 可执行以下命令 docker run -p 3306:3306 --name mysql3306 -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7 docker run -p 3307:3306 --n

测试mysql主从配置:实现一主一从读写分离

一.主从介绍Mysql主从又叫Replication.AB复制.简单讲就是A与B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,实现数据实时同步. 二.主从作用1.实时灾备,用于故障切换2.读写分离,提供查询服务3.备份,避免影响业务 三.在两台服务器上都按装mysql 1.环境准备关闭防火墙以SELINUX[[email protected] ~]# systemctl stop firewalld[[email protected] ~]# systemctl disable fi

Mysql主从配置,实现读写分离

大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢失的话,后果更是 不堪设想.这时候,我们会考虑如何减少数据库的联接,一方面采用优秀的代码框架,进行代码的优化,采用优秀的数据缓存技术如:memcached,如果资金丰厚的话,必然会想到假设服务器群,来分担主数据库的压力.Ok切入今天微博主题,利用MySQL主从配置,实现读写分离,减轻数据库压力.这种

笔记13(FTP配置、tomcat配置、resin配置、MySQL主从配置)

FTP服务搭建与配置 FTP介绍 FTP是File Transfer Protocol(文件传输协议,简称文传协议)的英文简称,用于在Internet上控制文件的双向传输. FTP的主要作用就是让用户连接一个远程计算机(这些计算机上运行着FTP服务器程序),并查看远程计算机中的文件,然后把文件从远程计算机复制到本地计算机,或把本地计算机的文件传送到远程计算机. 小公司用的多,大企业不用FTP,因为不安全. 使用vsftpd搭建ftp服务 centos上自带vsftpd 安装:yum instal