windows环境下搭建mysql主从
1. 环境
| 参数 | 说明 |
|---|---|
| 主库所在的操作系统 | win7 |
| 主库的版本 | mysql-5.6.46-winx64 |
| 主库的ip地址 | 127.0.0.1 |
| 主库的端口 | 3306 |
| 参数 | 说明 |
|---|---|
| 从库所在的操作系统 | win7 |
| 从库的版本 | mysql-5.6.46-winx64 |
| 从库的ip地址 | 127.0.0.1 |
| 从库的端口 | 3307 |
主库和从库版本可以一致也可以不一致,需要说明一点,如果两者版本不一致,一般主库的版本需要比从库的版本低,这样就可以避免由于版本问题,有些sql不能执行的问题。
2. 数据库安装
下载的是zip包的mysql 将其解压到本机即可

2.1 主库(master)的安装及配置
进入主库mysql-5.6.46-winx64目录中,在此目录中新建my.ini文件并添加一下配置。
[mysqld]
# 以下内容手动添加
[client]
port=3307
default-character-set=utf8
[mysqld]
#主库配置
server_id=1
log_bin=master-bin
log_bin-index=master-bin.index
# 跳过密码
skip-grant-tables
#端口
port=3306
character_set_server=utf8
#解压目录
basedir=D:\program\mysql-5.6.46-winx64
#解压目录下data目录
datadir=D:\program\mysql-5.6.46-winx64\data
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[WinMySQLAdmin]
D:\program\mysql-5.6.46-winx64\bin\mysqld.exe
将里面的路径修改成你自己的主库路径
以管理员权限打开cmd
cd /d D:\program\mysql-5.6.46-winx64\bin
mysqld --install master --defaults-file="D:\program\mysql-5.6.46-winx64\my.ini"
出现以下提示,表示服务安装成功。

将里面的路径修改成你自己的主库路径
其中的master为主库mysql的服务名称
删除master服务用sc delete master
启动主库的mysql服务器
net start master
net stop master 为停止命令

使用命令>mysql -uroot -P3306 -p登录master数据库(默认安装好的mysql的root用户是没有密码的)

登录上之后修改root用户的密码(这里修改成root)
执行命令
use mysql;
update user set password=password("root") where user="root";
flush privileges;

这样就设置好了root用户的密码了。(记得注销my.ini中的跳过密码配置,并重启master)

2.2 从库(slave)的安装与配置
进入主库D:\program\mysql-5.6.46-winx64-02目录中,在此目录中新建my.ini文件并添加一下配置。
[mysqld]
# 以下内容手动添加
[client]
port=3307
default-character-set=utf8
[mysqld]
#从库配置
server_id=2
relay-log-index=slave-relay-bin.index
relay-log=slave-relay-bin
# 跳过密码
skip-grant-tables
#端口
port=3307
character_set_server=utf8
#解压目录
basedir=D:\program\mysql-5.6.46-winx64-02
#解压目录下data目录
datadir=D:\program\mysql-5.6.46-winx64-02\data
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[WinMySQLAdmin]
D:\program\mysql-5.6.46-winx64-02\bin\mysqld.exe
安装从库服务。
cd /d D:\program\mysql-5.6.46-winx64-02\bin
mysqld --install slave --defaults-file="D:\program\mysql-5.6.46-winx64-02\my.ini"

启动从的mysql服务器
net start slave

同样的登录从库(mysql -uroot -P3307 -p)

修改从库root用户的密码为root
use mysql;
update user set password=password("root") where user="root";
flush privileges;

注销从库中的my.ini中的跳过密码配置,重启slave服务

至此,主、从数据库的安装及配置就完成了。
3. 关联主库(master)与从库(slave)
上面我们已经把master和slave相关配置文件都已添加,并分别启动了master与slave,现在我们分别登录到master和slave的mysql中,
master的mysql 执行命令 show master status查看master的状态
slave的mysql 执行命令 show slave status\G查看slave的状态

我们可以发现 ,master的状态下,生成了一个二进制的日志文件,而slave下是空的,所以我们现在就要把主库与从库关联起来。只需要让从库(slave)知道主库(master)的地址就可以了。
首先我们需要在主库(master)中创建一个用户用于与从库同步的用户名和密码(这里我创建一个test用户,密码为mysql),并给test用户授权,以用于主库操作从库。
create user test;
grant replication slave on *.* to '从库用户名(test)'@'从库主机地址(127.0.0.1)'identified by '密码(mysql)';
flush privileges;

现在我们切到从库(slave),把主库与从库联系起来。
change master to master_host='127.0.0.1',master_port=3306,master_user='test',master_password='mysql',master_log_file='master-bin.000001',master_log_pos=0;

然后执行命令 start slave; 开启主从同步

后执行命令查看 slave的状态
show slave status \G;
出现如下图,则开启主从跟踪成功

4. 验证主从同步
我们进入master和slave并查看他们的数据库,如下图:
然后我们在主库中创建一个数据库user,看一下从库有没有变化。

至此,主从同步已配置完毕。
注意不要往从库中写数据,如果从库写入数据,master_log_pos是不会变化的,主库的信息没有发生变化,当主库又变化和从库一样的操作时就有可能会产生冲突,因此,只能在主库中写数据,从库只能读数据,当然主库也可以读数据。
5. 主从恢复(补充)
在主库上使用show master status获取master_log_file和master_log_pos
再在从库上执行如下命令
stop slave;
change master to master_host='127.0.0.1',master_port=3306,master_user='test',master_password='mysql',master_log_file='master-bin.000001',master_log_pos=0;
start slave;
注意修改
master_log_file和master_log_pos以及其他配置信息
在从库上执行查询show slave status\G状态
windows环境下搭建mysql主从的更多相关文章
- Windows环境下部署MySQL主从并模拟升级到8.0
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 一.部署实例 1.下载2个软件 http://ftp.kaist.ac.kr/mysql/Downloads/MySQL- ...
- 搭建windows环境下(nginx+mysql+php)开发环境
搭建windows环境下(nginx+mysql+php)开发环境 1. 所需准备应用程序包 1.1 nginx 程序包nginx-1.0.4.zip或其他版本(下载地址: http ...
- linux下搭建mysql主从
在master上创建repl账户,用于复制. grant replication slave on *.* to 'repl'@'%' identified by 'P@$$W0rd'; flush ...
- freeSSHD在windows环境下搭建SFTP服务器
freeSSHD在windows环境下搭建SFTP服务器 0 建议现在windows环境下安装cygwin,否则在windows环境下cmd模式使用不了sftp去连接,可以利用win scp去测试连接 ...
- 【大数据系列】windows环境下搭建hadoop开发环境使用api进行基本操作
前言 搭建完hadoop集群之后在windows环境下搭建java项目进行测试 操作hdfs中的文件 版本一 package com.slp.hadoop274.hdfs; import java.i ...
- Windows环境下搭建MosQuitto服务器
Windows环境下搭建MosQuitto服务器 2018年04月16日 22:00:01 wistronpj 阅读数:1185 摘自:https://blog.csdn.net/pjlxm/art ...
- Apache Nifi在Windows环境下搭建伪群集及证书登录
代码地址如下:http://www.demodashi.com/demo/11986.html 前些时间做了关于Apache Nifi分布式集群的搭建分享,但很多时候要搭建分布式集群机器资源是个问题, ...
- windows 环境下搭建docker私有仓库
windows 环境下搭建docker私有仓库 1.在公用仓库中pull仓库镜像 docker pull regitry 2.启动仓库镜像 //-d意思是后台运行,-p是做端口映射,这里是将本地的50 ...
- Windows系统环境下创建mysql主从数据库方法(双向主从复制)
创建mysql主从数据库方法(双向主从复制) (一)Windows系统下的MySQL主从复制(单向复制) (1)环境说明: 1,Mysql版本:mysql5.7.20(主从机mysql版本必须一致) ...
随机推荐
- Confluence 6 上传文件
当你上传一个文件的时候,例如上传一个图片或者文档,上传的文件将会附加到当前页面上. 你可以选择在页面中将文件显示为一个链接,一个图片或者嵌入到页面中(使用宏). 上传一个文件到页面中你需要具有空间的权 ...
- Python惯例
“惯例”这个词指的是“习惯的做法,常规的办法,一贯的做法”,与这个词对应的英文单词叫“idiom”.由于Python跟其他很多编程语言在语法和使用上还是有比较显著的差别,因此作为一个Python开发者 ...
- 局域网 ARP 欺骗原理详解
局域网 ARP 欺骗原理详解 ARP 欺骗是一种以 ARP 地址解析协议为基础的一种网络攻击方式, 那么什么是 ARP 地址解析协议: 首先我们要知道, 一台电脑主机要把以太网数据帧发送到同一局域网的 ...
- Java 工程师成神之路
基础篇 → 什么是面向对象 面向对象.面向过程 是一种新兴的程序设计方法,或者是一种新的程序设计规范(paradigm),其基本思想是使用对象.类.继承.封装.多态等基本概念来进行程序设计.从现实世界 ...
- R_Studio(关联)对Groceries数据集进行关联分析
RGui的arules程序包里含有Groceries数据集,该数据集是某个杂货店一个月真实的交易记录,共有9835条消费记录,169个商品 #install.packages("arules ...
- OkHttp3 使用详解
一,简介 OkHttp 是一个高效的 HTTP 客户端,具有非常多的优势: 能够高效的执行 http,数据加载速度更快,更省流量 支持 GZIP 压缩,提升速度,节省流量 缓存响应数据,避免了重复的网 ...
- 第八周总结&实验报告六
总结:这周主要是学习异常的使用,已经怎么解决异常,总的来说学习的还是有点难度的,因为前面的知识还需要时间去弥补,这门课程还是要加油的学习! 这周主要所学: 一.异常 1.异常是导致程序中断运行的一种指 ...
- LeetCode 31. 下一个排列(Next Permutation)
题目描述 实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列. 如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列). 必须原地修改,只允许使用额外常 ...
- 代码实现:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.第二个完全数是28, //它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加, //编程找出1000以内的所有完数。
import java.util.ArrayList; import java.util.List; //一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3. ...
- Python基本语法_函数属性 & 参数类型 & 偏函数的应用
目录 目录 前言 软件环境 Python Module的程序入口 函数的属性 Python函数的创建 函数的参数 必备参数 缺省参数 命名参数 不定长参数 匿名参数 偏函数的应用 前言 Python除 ...