博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Windows操作系统下的MySQL主从复制及读写分离
阅读量:6730 次
发布时间:2019-06-25

本文共 2410 字,大约阅读时间需要 8 分钟。

一、主(master)配置

1、修改MySQL配置文件my.ini

[mysqld]

log-bin=mysql-bin

log-bin-index=mysql-bin.index
server-id=1
sync_binlog=1
binlog_format=mixed
binlog-do-db=test
binlog-ignore-db=mysql
binlog-ignore-db=performance_schema
binlog-ignore-db=information_schema

配置完成后重启MySQL服务。

2、授权给从服务器(slave)同步数据的账号密码

GRANT REPLICATION SLAVE ON *.*TO 'root'@'192.168.174.131' IDENTIFIED BY '123456';

参数说明:

  • root:slave连接master使用的账号
  • IDENTIFIED BY '123456' :slave连接master使用的密码
  • 192.168.174.130:slave IP

执行命令show master /G;

注意结果中的File和Position,配置从服务器(slave)时会用到。

 

二、从(slave)配置

1、修改MySQL配置文件my.ini

[mysqld]

server-id=2

log-bin=mysql-bin
relay-log-index=slave-relay-bin.index
relay-log=slave-relay-bin
sync_master_info=1
sync_relay_log=1
sync_relay_log_info=1

2、设置连接主服务器(master)的信息

change master to master_host='192.168.174.130',master_user='root',master_port=3306,master_password='root',master_log_file='mysql-bin.000008',master_log_pos='170'

参数说明:

  • master_host:master IP
  • master_user:master数据库通过GRANT授权的账号
  • master_port:master数据库使用的端口号
  • master_password:master数据库通过GRANT授权的密码
  • master_log_file:master数据库中通过show master status/G显示的File名称
  • _log_pos:master数据库中通过show master /G显示的Position数据

重启MySql服务。

执行命令:start slave。

执行命令:show slave /G。

当Slave_IO_Running与Slave_SQL_Running都为Yes时才算配置成功。

此时,服务器上test数据库里的数据就能同步到slave上的test数据库中。

 

三、使用MySQL Proxy实现读写分离

在此使用配置文件的方式来进行配置。

配置文件mysql-proxy.conf中的内容主要包括:

[-proxy]

admin-username=root
admin-password=123456
admin-lua-script=C:/mysql-proxy/lib/mysql-proxy/lua/admin.lua
proxy-backend-addresses=192.168.174.130:3306
proxy-read-only-backend-addresses=192.168.174.131:3306
proxy-lua-script=C:/mysql-proxy/share/doc/mysql-/rw-splitting.lua
log-file=C:/mysql-proxy/log/mysql-proxy.log
log-level=debug
daemon=true
keepalive=true

执行命令:

mysql-proxy -P 192.168.174.133:4040 --defaults-file=C:/mysql-proxy/bin/mysql-proxy.conf

查看日志文件-proxy.log:

2014-12-19 16:27:40: (critical) plugin proxy 0.8.5 started

2014-12-19 16:27:40: (debug) max  file-descriptors = 512
2014-12-19 16:27:40: (message)  listening on port 192.168.174.133:4040
2014-12-19 16:27:40: (message) added read/write backend: 192.168.174.130:3306
2014-12-19 16:27:40: (message) added read-only backend: 192.168.174.131:3306

出现以上日志信息则表示MySQL Proxy启动成功,此时便可以实现读写分离了。

注意:由于rw-splitting.lua中的min_idle_connections的默认值为4,即当会话数达到最小为4时,才会进行读写分离,在此我们将其改为1,则可直接进行读写分离。

 

MySQL下载地址:http://yunpan.cn/cfWp4tZDACvnp  提取码 b0db

MySQL Proxy下载地址:http://yunpan.cn/cfWpikpQWCsxM  提取码 ad1c

转载地址:http://algmo.baihongyu.com/

你可能感兴趣的文章
京东发力母婴市场的逻辑哲学
查看>>
使用任意设备的浏览器访问强大的PowerShell
查看>>
创建Oracle数据库
查看>>
在Hyper-V的虚拟机中安装集成服务
查看>>
谁能畅游智能电视红海:联想K82,还是乐视?
查看>>
Linux DISPLAY 变量设置
查看>>
Hyper-V 3.0部署PART 11:创建Hyper-V群集
查看>>
SFB 项目经验-32-批量为n台服务器导入PFX证书-实战(图解)
查看>>
IPod在Linux下的实战
查看>>
CentOS 7之Postfix部署系列 (二) CentOS网络设置
查看>>
svn实时同步案例!
查看>>
C#齿形数组
查看>>
25个精美的摄影师作品网站案例欣赏
查看>>
验证邮编和账户
查看>>
我记录网站综合系统 -- 技术原理解析[11:ActionProcessor流程-wojilu核心]
查看>>
Oracle操作
查看>>
(AS3)操作数组的每个元素:forEach,every,filter,map,some
查看>>
《CLR via C#》笔记——线程基础
查看>>
Python函数
查看>>
Redis多机功能总结
查看>>