mysql读写分离实战二-windows 上mysql主从数据库搭建及问题总结

根据前篇web项目的搭建后,需要搭建主从数据库,这里在windows服务器上搭建了主从结构的mysql,这里在记录下在本机模拟搭建过程
在windows上安装和linux还是有些不同,不注意就会耽误不少时间
一 下载安装包和安装
https://dev.mysql.com/downloads/file/?id=469273 下载的安装包是Archive
需要手工安装且建立服务和初始化data目录,具体可以在网上搜索有很多具体安装方法。
二 建立从节点
1把主服务器的安装目录C:\Program Files\MySQL\MySQL Server 5.7所有文件都copy到另一个目录D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7。
2修改复制过来的my.ini文件参数
包括端口和路径
port = 3307
basedir = "D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7"
datadir = "D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7\data"
3建立mysql从服务器服务
mysqld install MySQLM --defaults-file="D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7\my.ini"
4修改对应注册表里服务启动项的内容
注册表HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\MySQL57\ImagePath里使用的路径改成
"D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7\bin\mysqld" --defaults-file=D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7\my.ini MySQLS
mysqld_multi.pl --defaults-extra-file=D:\anzhuang\MySQL\mysqlSlave\MySQL Server 5.7\my.ini start 3307
以便启动mysql时可以找到对应my.ini文件启动
三 主节点配置
1修改主节点和从节点上my.ini
[mysqld]
server-id = 1  
binlog-do-db=test #要同步的数据库
#binlog-ignore-db=mysql   #不同步的数据库,如果指定了binlog-do-db这里应该可以不用指定的
log-bin=mysql-bin #要生成的二进制日记文件名称

修改从配置文件:
[mysqld]
server-id = 2
log-bin    = mysql-bin
replicate-do-db=test

2上创建用户并授权
create user 'repla'@'127.0.0.1' identified by 'test';
GRANT REPLICATION SLAVE ON *.* TO 'repla'@'127.0.0.1';
3创建test数据库

4 物理备份test目录到从库
把datadir指定的目录的data目录copy到从目录
5 show master status
查看file和position字段对应的参数;
+------------------+----------+--------------+------------------+--------------
----+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid
Set |
+------------------+----------+--------------+------------------+--------------
----+
| mysql-bin.000006 |     1847 | test         |                  |
    |
+------------------+----------+--------------+------------------+--------------

四从节点配置
1启动从节点mysql服务
mysql -uroot -P3307 -p123456 如果端口不同,必须制定端口,才能在一台机器上同时启动多实例

2 接收主节点传送日志
change master to master_host='127.0.0.1',master_port=3306,master_user='repla',master_password='test',master_log_file='mysql-bin.000006',master_log_pos=1847;

3启动从数据库复制功能
start slave

最后在主库插入数据后,从库就能看到主库的数据了。

问题总结
1这里的my.ini文件在注册表里有指定,无论是否使用命令指示使用自己命令的ini,系统都会根据注册表里的my.ini文件位置去读取并启动db。
比如用命令C:\Program Files\MySQL\MySQL Server 5.7\bin>mysql --defaults-file="D:\anzhuang\MySQL\my.ini" -uroot -p
想使用自己定义的my.ini.但注册表HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\MySQL57\ImagePath里使用的路径不是
这个路径时,还会按照注册表的路径读取文件。
如果在windows上安装,要正确识别my.ini位置,具体可根据服务选择或注册表信息判断my.ini位置

2 备份时可采用物理备份和逻辑备份,如果是物理备份注意把主库的data目录下的全部文件复制到slave
这个data目录一定是datadir参数中指定的目录,这点可能会采用软件安装目录下的data目录而不是数据目录
3 采用物理备份时很可能把auto.cnf文件也复制到slave,造成主备之间的UUID不一致,这里的解决办法是在slave
重新命名auto.cnf,然后重启备库,重新生成新的UUID
可以参考网址http://www.linuxidc.com/Linux/2015-02/113564.htm
4 在slave上需要验证主从是否开始传送日志方法
mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 127.0.0.1
                  Master_User: repla
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000011
          Read_Master_Log_Pos: 1684
               Relay_Log_File: SDSC-WIN7-ZHANGLU-relay-bin.000002
                Relay_Log_Pos: 1595
        Relay_Master_Log_File: mysql-bin.000011
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: test
    ......
 Slave_IO_Running: Yes Slave_SQL_Running: Yes都是Yes 就对了。
 可能出现问题是要多次stop slave后多次执行change master to命令。

时间: 2024-08-02 15:39:12

mysql读写分离实战二-windows 上mysql主从数据库搭建及问题总结的相关文章

spring aop实现mysql读写分离(可用于SAE的mysql数据库)

spring aop实现mysql读写分离(可用于SAE的mysql数据库)  发表于 2014-3-12 12:46:53 |只看该作者 |倒序浏览          前言:SAE的MySQL数据库提供了主从数据库,我们可以向主数据库写数据,同时从从库里面读取数.如果在程序中不做数据库的读写切换是无法正常使用SAE的MYSQL数据库的,我们可以使用spring的aop功能实现mysql主从数据库的切换          在application-datasource.xml中配置master和

mysql读写分离实战准备一

一目的 首先准备一个web网站,这里模拟一个网站的页面,主要对开源网页实现动态存取,之后将使用本页面进一步实现对mysql的读写分离功能 二架构 前台是开源网页的页面,具体例子可从如下网站下载 http://www.superslide2.com/ 后台采用springboot+thymeleaf开发 1前端页面整合 复制网站实例页面,到如下路径/template/case1page   复制静态页面包括js文件到/static 2后台整合 Pom中加入相应jar包依赖,且未方便开发可以加入热部

云服务器 ECS 配置:利用MySQL读写分离,提升应用数据吞吐性能

利用MySQL读写分离,提升应用数据吞吐性能 背景 一般情况下,对数据库的读和写都在同一个数据库服务器中操作时,业务系统性能会降低.为了提升业务系统性能,优化用户体验,可以通过读写分离来减轻主数据库的负载.本篇文章分别从应用层和系统层来介绍读写分离的实现方法. 应用层实现方法: 应用层中直接使用代码实现,在进入Service之前,使用AOP来做出判断,是使用写库还是读库,判断依据可以根据方法名判断,比如说以query.find.get等开头的就走读库,其他的走写库. 优点: 1.多数据源切换方便

MaxScale:实现MySQL读写分离与负载均衡的中间件利器

  1 MaxScale 是干什么的?  配置好了MySQL的主从复制结构后,我们希望实现读写分离,把读操作分散到从服务器中,并且对多个从服务器能实现负载均衡.   读写分离和负载均衡是MySQL集群的基础需求,MaxScale 就可以帮着我们方便的实现这些功能.       2 MaxScale 的基础构成  MaxScale 是MySQL的兄弟公司 MariaDB 开发的,现在已经发展得非常成熟.MaxScale 是插件式结构,允许用户开发适合自己的插件.   MaxScale 目前提供的插

MySQL读写分离技术

阅读目录 1.简介 2.基本环境 3.配置主从复制 4.MySQL读写分离配置 4.1.安装lua 4.2.安装mysql-proxy 5.MySQL读写分离测试 1).修改rw-splitting.lua文件 2).修改完成后,启动mysql-proxy 3).创建用于读写分离的数据库连接用户 4).测试登陆账号proxy1@192.168.95.13进行添加数据 5).关闭12mysql的从复制 6).证明写分离 7).证明读分离 6.建议 回到顶部 1.简介 当今MySQL使用相当广泛,随

PHP实现MySQL读写分离

本代码是从uchome的代码修改的,是因为要解决uchome的效率而处理的.PHP实现的Mysql读写分离 本代码是从uchome的代码修改的,是因为要解决uchome的效率而处理的. PHP实现的Mysql读写分离 主要特性: 简单的读写分离 一个主数据库,可以添加更多的只读数据库 读写分离但不用担心某些特性不支持 缺点:同时连接两个数据库 英文比较烂,也写几个字吧 php code for mysql read/write split feature: simply rw split one

PHP实现的Mysql读写分离

本代码是从uchome的代码修改的,是因为要解决uchome的效率而处理的.这个思维其实很久就有了,只是一直没有去做,相信也有人有同样的想法,如果有类似的,那真的希望提出相关的建议. 封装的方式比较简单,增加了只读数据库连接的接口扩展,不使用只读数据库也不影响原代码使用.有待以后不断完善.. 为了方便,试试建立了google的一个项目: http://code.google.com/p/mysql-rw-php/ 希望给有需要的朋友带来帮助. PHP实现的Mysql读写分离 主要特性: 简单的读

使用PHP实现Mysql读写分离

本代码是从uchome的代码修改的,是因为要解决uchome的效率而处理的.这个思维其实很久就有了,只是一直没有去做,相信也有人有同样的想法,如果有类似的,那真的希望提出相关的建议. 封装的方式比较简单,增加了只读数据库连接的接口扩展,不使用只读数据库也不影响原代码使用.有待以后不断完善.. 为了方便,试试建立了google的一个项目:http://code.google.com/p/mysql-rw-php/希望给有需要的朋友带来帮助. PHP实现的Mysql读写分离主要特性:1.简单的读写分

Magento数据库配置选项,以及mysql 读写分离

1.数据库配置 [mysqld] key_buffer = 512M max_allowed_packet = 64M table_cache = 512 sort_buffer_size = 4M read_buffer_size = 4M read_rnd_buffer_size = 2M myisam_sort_buffer_size = 64M tmp_table_size = 128M query_cache_size = 96M query_cache_type = 1 thread