Windows下搭建MySQL Master Slave

转:http://www.cnblogs.com/gaizai/p/3248207.html

http://www.cnblogs.com/gaizai/archive/2013/03/15/2961868.html   MySQL表数据迁移自动化

http://www.cnblogs.com/gaizai/archive/2012/10/23/2735556.html  Ubuntu10下MySQL搭建Master Slave

一、背景

服务器上放了很多MySQL数据库,为了安全,现在需要做Master/Slave方案,因为操作系统是Window的,所以没有办法使用keepalived这个HA工具,但是我们可以接受人工进行切换,有什么好的方案呢?

二、几种Master/Slave逻辑架构图

(Figure1:单Master-单Slave)

(Figure2:单Master-多Slave)

(Figure3:单Master-级联Slave)

(Figure4:Master/Slave部署逻辑图)

三、搭建过程

环境:Windows Server 2008 R2 + mysql-5.5.22-winx64

主服务器(Master):192.168.1.66

从服务器(Slave):192.168.1.67

使用Master/Slave架构,Slave为只读模式;

(一) 配置主服务器(Master)

1. 编辑数据库配置文件my.ini,在[mysqld]标签下面加入下面代码:

log-bin=mysql-bin

server-id=1

innodb_flush_log_at_trx_commit=1

sync_binlog=1

binlog_do_db=barfoo_weibo_hottop

binlog_ignore_db=mysql

说明:

1) log-bin=mysql-bin启用Binary Log,会在数据文件夹中生成一系列的滚动文件,类似:mysql-bin.000002

2) server-id=1中的1可以任定义,只要是唯一的就行,为了与其它Master和Slave进行区别;

3) innodb_flush_log_at_trx_commit = 0,每秒写一次trax log,并执行fsync;

innodb_flush_log_at_trx_commit = 1,每次trax 提交的时候写一次trax log, 并执行fsync;

innodb_flush_log_at_trx_commit = 2,每次trax 提交的时候写一次trax log, 不会执行fsync;

4) sync_binlog=1表示异步进行日志记录;

5) binlog_do_db=barfoo_weibo_hottop是表示只对数据barfoo_weibo_hottop做日志记录,如果想记录多个数据库,添加多几条binlog_do_db就可以了;

6) binlog_ignore_db=mysql表示忽略备份mysql;不加binlog_do_db和binlog_ignore_db,那就表示备份全部数据库。

2. 重启MySQL服务

3. 在Master服务器新建一个用户赋予“REPLICATION SLAVE”的权限,你不需要再赋予其它的权限,这里指定的IP为Slave的IP;

mysql>CREATE USER [email protected]‘192.168.1.67‘ IDENTIFIED BY ‘BarFoo2013‘;

mysql>GRANT REPLICATION SLAVE ON *.* TO [email protected]‘192.168.1.67‘ IDENTIFIED BY ‘abc2013‘;

4. 在Master服务器执行下面的脚本,让数据库只能读;

mysql>FLUSH TABLES WITH READ LOCK;

5. 拷贝数据库文件夹和ibdata1文件到本地临时文件夹中,马上执行下面的步骤;

6. 查看Master服务器的状态,记下File及Position的值,后面设置Slave服务器的时候需要用到;

mysql>SHOW MASTER logs;

mysql>SHOW MASTER STATUS;

(Figure1:Master状态)

7. 对表进行解锁,恢复数据库读写;

mysql>UNLOCK TABLES;

8. 使用FTP等工具把第5步骤的临时文件传到Slave服务器;

(二) 配置从服务器(Slave)

1. 编辑数据库配置文件my.ini,在[mysqld]的下面加入下面代码,可以自己定义数值,只要保证唯一的就行,与Master的能区分开就行;

server-id=2

read-only=1

2. 重启MySQL

3. 登录MySQL服务器,执行下面的脚本命令:

mysql>CHANGE MASTER TO

MASTER_HOST=‘192.168.1.66‘,

MASTER_USER=‘viajar‘,

MASTER_PASSWORD=‘abc2013‘,

MASTER_PORT=3309,

MASTER_LOG_FILE=‘mysql-bin.000005‘,

MASTER_LOG_POS=7179684,

MASTER_CONNECT_RETRY=30;

说明:

1) MASTER_HOST:Master服务器的IP;

2) MASTER_USER:配置主服务器时建立的用户名;

3) ASTER_PASSWORD:用户名对应的密码;

4) ASTER_PORT:主服务器mysql端口,如果未曾修改,默认即可;

5) MASTER_LOG_FILE:log文件名,参考Figure1;

6) MASTER_LOG_POS:只上次备份时的log文件的偏移量,参考Figure1;

7) MASTER_CONNECT_RETRY:重新连接Master的时间间隔,单位为秒;

4. 启动Slave进程,执行下面的脚本命令;

mysql>START SLAVE;

5. 检查主从同步状态,执行下面的脚本命令,其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。

mysql>SHOW SLAVE STATUS;

(Figure2:Slave状态1)

(Figure3:Slave状态2)

6. 查看Slave服务器的MySQL日志;

(Figure4:Slave日志文件)

四、补充说明

1. 查看帮助

mysql>help

2. 查看slave帮助

mysql>help slave

3. 查找当前有哪些二进制日志文件

mysql> show binary logs;

4. 删除mysql-bin.000018之前的所有二进制日志文件

mysql> purge binary logs to ‘mysql-bin.000018‘;

5. 从 MySQL 5.1.12 开始,能够用以下三种形式来告终:基于SQL语句的复制(statement-based replication, SBR),基于行的复制(row-based replication, RBR),混杂形式复制(mixed-based replication, MBR)。相应地,binlog的款式也有三种:STATEMENT,ROW,MIXED。MBR 形式中,SBR 形式是默认的。

#binlog_format="STATEMENT" 
#binlog_format="ROW" 
#binlog_format="MIXED"

当然了,也能够在运行时动态修正binlog的款式。例如

mysql> SET SESSION binlog_format = ‘STATEMENT‘; 
mysql> SET SESSION binlog_format = ‘ROW‘; 
mysql> SET SESSION binlog_format = ‘MIXED‘;

mysql> SET GLOBAL binlog_format = ‘STATEMENT‘; 
mysql> SET GLOBAL binlog_format = ‘ROW‘; 
mysql> SET GLOBAL binlog_format = ‘MIXED‘;

6. MySQL同步故障:Slave_SQL_Running:No

mysql> slave stop;

mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;

mysql> slave start;

五、疑问

(一) 复制级别有以下几种,默认级别是那种?如何显式设置这个值?

1. Row Level:5.1.5开始支持。mater记录每行数据的更改日志,slave根据日志逐行应用。优点:数据一致性更有保障。缺点:可能造成日志文件比较大;

2. Statement Level:master记录每个执行的query语句以及一些上下文信息,slave节点根据这些信息重新在slave上执行。优点:binary log比较小。缺点:某些情况下数据一致性难以保障;

3. Mixed Level:MySQL根据情况选择哪种复制方式。5.1.8开始支持。

(二) 常用架构有以下几种,我想要的效果是:当MasterA宕机之后,MasterB还能读写,在MasterA在恢复之后重新让MasterA成为主Master。

1. Master-Slaves:通常都采用这种方式;

2. Dual Master(Master-Master):2个master节点互相同步更新。因为MySQL的异步复制方式,为了防止数据冲突造成的不一致性,一般仅将其中一台用于写操作,另一台不用或仅用于读操作。目的是其中一台master停机维护或者故障中断时可以使用另一台master;

3. 级联复制(Master-Slaves-Slaves):在Master Slaves中,如果slaves过多replication将增加master的负载,这时可以让master只向其中几台slave分发更新日志,这几台slave作为一级节点再向下级节点分发更新日志。

(三) 如果slave报错或者宕机一段时间,那么应该如何重新同步宕机时间master的数据到slave呢?

(四) 在Master设置binlog_do_db=test的时候,如何可以设置记录多个数据库?

解答:直接在配置文件my.ini加入多条binlog_do_db就可以了;

(五) 每天的日志文件就有10GB,如何清理?如何维护?有没什么设置或者方法可以减少日志量呢?

六、参考文献

windows下Mysql master-slave配置

搭建MySql的Master/Slave架构

Linux MySQL主从复制(Replication)配置

13.4.2.1. CHANGE MASTER TO Syntax

innodb_flush_log_at_trx_commit option

innodb_flush_log_at_trx_commit

理解MySQL——复制(Replication)(图形并茂)

时间: 2024-08-10 04:11:09

Windows下搭建MySQL Master Slave的相关文章

Windows下搭建MySql Master-Master Replication

1.首先下载最新版的MySql Server (http://dev.mysql.com/downloads/windows/installer/) 2.安装MySql Server到两台机器上 MySql 1: 192.168.0.104 (以下简称104) MySql 2: 192.168.0.103  (以下简称103) 3. 配置Mysql Server启动Binary Logging. 在104的my.ini文件(一般在C:\ProgramData\MySql\MySql Server

linux下搭建mysql主从

在master上创建repl账户,用于复制. grant replication slave on *.* to 'repl'@'%' identified by '[email protected]$$W0rd'; flush privileges; 与windows下搭建mysql主从的区别: 二进制日志的路径格式不一样 master: my.cnf部分配置(master): thread_handling = pool-of-threads thread_pool_oversubscrib

windows下搭建Apache+Mysql+PHP开发环境

原文:windows下搭建Apache+Mysql+PHP开发环境 要求 必备知识 熟悉基本编程环境搭建. 运行环境 windows 7(64位); Apache2.2;MySQL Server 5.5php-5.3 下载地址 环境下载 官方下载地址 Apache MySql PHP 至于我使用的版本已经上传到百度云提供大家下载了,这里就不多啰嗦了!! Apache Apache的安装和普通的应用程序安装没什么太大的区别,关键是配置.打开安装路径下的"conf\httpd.conf"文

Windows下搭建PHP开发环境,整合Apache+PHP+MySQL(举例软件为32位)

原文来自:http://www.cnblogs.com/pharen/archive/2012/02/06/2340628.html 在原作者的基础上,只是做了详细的解释.避免走弯路.(注:红色字体为本人加的) 一.准备工作-下载所需软件 Apache  httpd-2.2.22-win32-x86-openssl-0.9.8t.msi PHP       php-5.3.10-Win32-VC9-x86.zip MySQL   mysql-5.5.20-win32.msi 二.安装软件 安装A

Windows下搭建PHP环境:Apache+PHP+MySQL

由于换电脑或重装系统后常需要重新搭建PHP环境,此次简单记录一下Windows下搭建PHP环境的过程,具体步骤可以参照网上资料 准备工作: Windows下手工搭建PHP环境需要先下载相应的软件,此次下载的软件版本如下图所示: 安装过程: 一.安装Apache 双击安装,与安装其他Windows软件没有什么区别 在填Server Infomation时,并没有特殊规定,只要输入的信息符合格式即可 安装完成之后,在浏览器输入http://localhost,如果显示It Works!,表示Apac

Windows下搭建论坛

Windows下搭建论坛 真正的O基础架构,一步一步走向成功 转载请注明原作者出处 环境准备篇 安装集成包软件 解压后如下 以管理员身份运行setup的批处理 选择推荐的apache版本 选择推荐的mysql版本 解压完成执行初始化 当出现以下原因是因为包含了中文字符 为解决此问题将他移动到非中文字符的目录下 运行init.cmd的批处理文件开始初始化 设置完成及初始化完成,请记住数据库密码 完成后打开访问本地地址验证是否安装成功 测试连接数据库是否成功 论坛搭建篇 解压Discuz论坛文件如下

Windows下搭建go语言开发环境 以及 开发IDE (附下载链接)

1.下载 并且 安装 Go安装包 =========================================================== 在CSDN上传了我的版本,供大家下载: =========================================================== go1.2.windows-386.msi : http://download.csdn.net/detail/shuideyidi/7718563 go1.2.1.windows-am

MySQL集群---②Windows平台搭建MySQL CLUSTER集群

本文将通过两台电脑来简单介绍一下Windows平台如何搭建MySQL集群. MySQL集群支持多台电脑,本文搭建的MySQL集群以两台机子为例,其中一台(IP为192.168.24.33)部署管理节点.数据节点和SQL节点,另一台(IP为192.168.24.82)部署数据节点和SQL节点. 实际应用中,不要将管理节点跟数据节点部署到一台机子上,因为如果数据节点宕机会导致管理节点不可用,同时整个MySQL群集也就都不可用了.所以一个MySQL群集理想情况下至少有三台服务器,将管理节点单独放到一台

本地windows下搭建git的本地服务器

本地windows下搭建git的本地服务器 准备工作: 本地安装java环境,配置环境变量(略) 下载gitblit文件,百度一大堆 开始第一步: 减压gitblit压缩包到某个目录下,比如我在:H:\gitblit 第二步: 修改gitblit安装目录下的data文件下的gitblit.properties 第17行处:include = defaults.properties 修改为 include = my.properties 第三步: 从data文件夹下找到defaults.prope