Windows实现MySQL5.7主从复制(详细版)

使用免安装版本(官网下载地址)

在Windows上安装两种MySQL服务并同时开启服务


1.下载配置

打开解压文件所在位置,就新建一个配置文件my.ini。


2.主库安装

主库的my.ini配置文件如下:

[mysqld]
#设置主库端口,注意须是不被占用的端口号
port = 3301
#设置mysql的安装目录
basedir=C:\Users\xxx\Desktop\mysql-5.7.44-winx64\mysql-3301
#设置mysql数据的存储目录,如果该路径下不存在data文件夹,会在安装时自行创建
datadir=C:\Users\xxx\Desktop\mysql-5.7.44-winx64\mysql-3301\data
#二进制文件名称,注意这里的mysql-bin是自行命名,后续所有步骤都要与之对应
log-bin=mysql-bin
#设置服务器的id,要求各个服务器的id必须不一致
server-id = 1                     

接下来以管理员方式运行cmd,进入到安装目录下的bin 路径下:

运行如下命令:

mysqld --initialize --console

#3301为自己的端口号

mysqld --install mysql_master_3301

#开启服务时,会在最后生成随机密码,记得保存用于登录


net start mysql_master_3301

#第一次的登录用随机密码

mysql -uroot -P3301 -p

#修改密码

alter user 'root'@'localhost' identified by '123456';

#可以删除服务的命令(如果没错就不用执行!!!!!)


net stop mysql_master_3301
mysqld remove mysql_master_3301

打开Navicat,测试连接。


3.从库安装

从库的my.ini配置文件如下:

[mysqld]
#设置主库端口,注意须是不被占用的端口号
port = 3302
#设置mysql的安装目录
basedir=C:\Users\xxx\Desktop\mysql-5.7.44-winx64\mysql-3302
#设置mysql数据的存储目录,如果该路径下不存在data文件夹,会在安装时自行创建
datadir=C:\Users\xxx\Desktop\mysql-5.7.44-winx64\mysql-3302\data
#二进制文件名称,注意这里的mysql-bin是自行命名,后续所有步骤都要与之对应
log-bin=mysql-bin
#设置服务器的id,要求各个服务器的id必须不一致
server-id = 2                     

修改bin中的mysql.exemysqld.exe名称,并且将对应命令进行修改。

接下来以管理员方式运行cmd,进入到安装目录下的bin 路径下:

运行如下命令:

mysqld --initialize --console

mysqld --install mysql_master_3302

net start mysql_master_3302

mysql -uroot -P3301 -p

alter user 'root'@'localhost' identified by '123456';

之后的所有操作,保证两个MySQL服务都开启,然后在Navicat中同时连接两个服务:


4.进行主从复制配置

在主库新建用户:

这里的主机输入%,表示可以接收所有IP的服务端访问,过期密码选择NEVER(没有就不管他) 

在服务器权限中勾选 File 和 Replication Slave并保存。

在主库端输入查询语句:

show master status;

记录这两个值!!!从库配置时需要使用。

-----------------

打开从库,输入语句:

#关闭slave,此时会报错(个别情况,报错问题解决办法再下面)


stop slave;

#注意检查对应信息


change master to master_host='loc alhost',
master_user='xxx',
master_password='123456',
master_port=3301,
master_log_file='mysql-bin.000002',
master_log_pos=1024;

#开启slave

start slave;

在 Slave_SQL_Running 和 Slave_IO_Running 都显示yes,表示主从复制配置完成。


报错问题解决:

#查询ONLY_FULL_GROUP_BY 是否存在,若存在则执行下一步

SELECT @@sql_mode;

#将ONLY_FULL_GROUP_BY 修改为空

SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));


5.测试主从复制

登录入主库,输入

create database test;

然后再从库进行刷新查询,即可看到从库也有了test数据库,证明主从复制完成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/582268.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uniapp开发移动端遇到的问题记录

1. 键盘弹起时页面整体上移问题 很常见但我解决过程中遇到了很多问题 我的键盘没有遮盖到输入框,但手机键盘弹起后,form部分会整体上移一点,并且底部的操作也会弹到键盘上方 网上写得很复杂,什么动态赋值高度balabala。看到有一…

英文vos安装,vos3000 web3.0

英文vos安装,vos3000英文软件工具安装,Web V3.0是一个安全且强大的批发 VOIP 计费解决方案,具有新的 Web 界面和无与伦比的令人惊叹的新功能。现在使用移动应用程序或网络浏览器控制您的 VOS3000 VOIP 计费服务器 yumsed -i "s|enabled…

使用pytorch搭建ResNeXt并基于迁移学习训练

冻结除最后全连接层以外的所有权重,只去单独训练它最后一层的的权重,这个方法,冻结了所有网络的权重。 for param in net.parameters():param.requires_grad False

C语言之指针和函数

目录 作为函数参数的指针 二值互换 scanf函数和指针 指针的类型 空指针 标量型 在C语言程序中,指针的一个重要作用就是作为函数参数使用,下面我们就来学习作为函数参数的指针的相关内容。 作为函数参数的指针 假如我有一个神奇的能力,能…

win32 WM_MENUSELECT消息学习

之前写了一些win32的程序,处理菜单单击都是处理WM_COMMAND消息,通过 LOWORD(wParam) 获取菜单ID,判断单击的是哪个菜单项; 还有一些其他菜单消息; 当在菜单项中移动光标或鼠标,程序会收到许多WM_MENUSELEC…

stm32f103系统滴答定时器

简介 SysTick定时器, 是一个24位的定时器, 只能向下计数(n->0). 从RELOAD寄存器中自动重装载定时初值. 24位可以粗略约等于16M个数字. 寄存器 库函数配置系统定时器中断 选择8分频还是系统时钟源. 系统滴答次数, 也就是重装载值, 每次结束都会产生一个中断. 使用系统时钟…

软件测试/测试开发丨学习笔记之Python运算符

运算符的作用 Python基础语法的内容通常表示不同数据或变量之间的关系 算数运算符 运算符描述加-减*乘/除%取模**幂//取整除 取模与取余区别 概念上:取模是计算机术语,取余属于数学概念; 结果上:当同号的两个数相除&#xff…

程序员如何高效学习技术?

我们相信努力学习一定会有收获,但是方法不当,既让人身心疲惫,也没有切实的回报。 不少朋友每天都阅读技术文章,但是第二天就忘干净了。工作中领导和同事都认可你的沟通和技术能力,但是跳槽面试却屡屡碰壁。面试官问技术…

Google Chrome 现在会在后台扫描泄露的密码

谷歌表示,Chrome 安全检查功能将在后台运行,检查网络浏览器中保存的密码是否已被泄露。 如果桌面用户正在使用标记为危险的扩展程序(从 Chrome Web Store 中删除)、最新的 Chrome 版本,或者如果启用安全浏览来阻止 Go…

我的NPI项目之行业黑话 -- 电子/机构/软件/认证

因为最近的NPI项目,参加了很多项目的会议,有电子/机构/软件/认证相关的各方面的专业词汇就出现了。这里我将之称为黑话,就是对我(纯软件) 来说是黑盒的话。这里简单记录并用于理解。 EE有关: Layout,一直…

基于Qt之QChart 图表(优美的曲线图案例)

## 项目演示 平台:ubuntu18.04 Qt版本:QT5.14.2 源码位置GitCode:https://gitcode.com/m0_45463480/QCharts/tree/main ## QChart 图表 自从 Qt 发布以来,给跨平台的用户带来很多便利。在 Qt5.7 之前,Qt 在开源社区版本里没有 Qt Charts(自带的绘图组件库)。这使得像…

安卓开发学习笔记

Android发展历史 开发工具 Android Studio 安装工具 下载页面:下载 Android Studio 和应用工具 - Android 开发者 | Android Developers 安装步骤 要求代理,关闭就可以 下载SDK 完成后创建新项目 努力学习中~

12-28

#include <iostream>using namespace std; class Person {int *age;string &name; public:void ss(){cout<<"年龄:"<<*age<<endl<<"名字:"<<name<<endl;}//拷贝构造函数(深拷贝&#xff09;Person(const Pe…

docker学习(二十一、network使用示例container、自定义)

文章目录 一、container应用示例1.需要共用同一个端口的服务&#xff0c;不适用container方式2.可用示例3.停掉共享源的容器&#xff0c;其他容器只有本地回环lo地址 总结 二、自定义网络应用示例默认bridge&#xff0c;容器间ip通信默认bridge&#xff0c;容器间服务名不通 自…

C++ DAY1 作业

1.定义自己的命名空间myspace&#xff0c;并在myspace中定义一个字符串&#xff0c;并实现求字符串长度 #include <iostream>using namespace std; namespace myspace {string str;int length_fun(){getline(cin,str);int i 0;while(str[i] ! \0){i;}return i;}} using…

案例214:基于微信小程序的水果销售系统的设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder …

【网络安全 | 指纹识别工具】WhatWeb使用详析

前言 WhatWeb 是一款用于识别 Web 应用程序和 Web 服务器的开源工具。它可以识别网站使用的编程语言、Web 框架、Web 服务器软件、Web 应用程序等信息&#xff0c;从而帮助安全测试人员快速了解目标网站的技术特征&#xff0c;发现可能存在的漏洞。 本文将对 WhatWeb 的使用方法…

git 如何将某个分支的某个提交复制到另外一个分支

请直接去看原文: 原文链接:git 如何将某个分支的某个提交复制到另外一个分支_gitlab里面的markdown文件可以复用其他分支的吗-CSDN博客 --------------------------------------------------------------------------------------------------------------------------------…

GIT如何重新生成ssh密钥过程

GIT如何重新生成ssh密钥过程 一、生成密钥前需要把之前的密钥删除吆 第一步&#xff1a;重新配置用户名和邮箱&#xff08; Git Bash 或命令窗口&#xff09; 1、配置用户命令&#xff1a;git config --global user.name “xxxxx” 2、配置邮箱命令&#xff1a;git config …

【我与Java的成长记】之this引用和构造方法的使用详解

系列文章目录 能看懂文字就能明白系列 C语言笔记传送门 &#x1f31f; 个人主页&#xff1a;古德猫宁- &#x1f308; 信念如阳光&#xff0c;照亮前行的每一步 文章目录 系列文章目录&#x1f308; *信念如阳光&#xff0c;照亮前行的每一步* 前言一、this的使用this引用的特…