VMware——WindowServer2012R2环境安装mysql5.7.14解压版_互为主从(图解版)

news2024/11/17 23:33:10

目录

    • 一、服务器信息
    • 二、192.168.132.35服务器上安装mysql(
      • 2.1、环境变量配置
      • 2.2、安装
        • 2.2.1、修改配置文件内容
        • 2.2.2、初始化mysql并指定超级用户密码
        • 2.2.3、安装mysql服务
        • 2.2.4、启动mysql服务
        • 2.2.5、登录用户管理及密码修改
        • 2.2.6、开启远程访问
    • 三、192.168.132.36服务器上安装mysql(
    • 四、mysql互为主从配置
      • 4.1、修改两台服务器上mysql配置文件
        • 4.1.1、修改192.168.132.35服务器上mysql配置
        • 4.1.2、修改192.168.132.36服务器上mysql配置
      • 4.2、创建两台服务器Replication用户
        • 4.2.1、192.168.132.35服务器上创建Replication用户
        • 4.2.2、192.168.132.36服务器上创建Replication用户
      • 4.3、查看两台服务器的mysql bin log位置
        • 4.3.1、查看192.168.132.35服务器上mysql bin log位置
        • 4.3.2、查看192.168.132.36服务器上mysql bin log位置
      • 4.4、设置两台服务器的Slave Replication
        • 4.4.1、设置192.168.132.35服务器上Slave Replication
        • 4.4.2、设置192.168.132.36服务器上Slave Replication
      • 4.5、查看两台主机是否设置成功
        • 4.5.1、查看192.168.132.35服务器是否设置成功
        • 4.5.2、查看192.168.132.36服务器是否设置成功
    • 五、mysql互为主从测试
      • 5.1、192.168.132.35服务器创建数据库,并在192.168.132.36服务器上查看是否有192.168.132.35服务器创建的数据库
      • 5.2、192.168.132.36服务器创建数据库,并在192.168.132.35服务器上查看是否有192.168.132.36服务器创建的数据库 - **192.168.132.35、192.168.132.36服务器把创建的数据库删除,如下图:**
    • 六、报错解决
      • 6.1、报错slave failed to initialize relay log info structure from the repository
      • 6.2、报错Could not find first log file name in binary log index file
      • 6.3、报错Client requested master to start replication from position > file size

一、服务器信息

服务器ip服务器角色
192.168.132.35主从
192.168.132.36主从

二、192.168.132.35服务器上安装mysql(

2.1、环境变量配置

  • 解压版mysql-5.7.14-winx64.zip版本mysql到C:\software\目录下
    在这里插入图片描述
  • 右击计算机―【属性】―【高级系统设置】―【环境变量】-【系统变量】-【新建】
    说明:由于我把mysql安装在C:\software\mysql-5.7.14-winx64文件下所以以这个路径为例
    变量名:MYSQL_HOME
    变量值:C:\software\mysql-5.7.14-winx64
    在这里插入图片描述
  • 找到系统变量“Path”然后点击【编辑】按钮。在变量值后面加上【 ;%MYSQL_HOME%\bin;】一定要记住每增加一条变量都要用分号隔开,点击【确认】
    变量名:Path
    变量值:在原有的值后面加上:;%MYSQL_HOME%\bin;
    在这里插入图片描述

2.2、安装

2.2.1、修改配置文件内容
  • 找到mysql安装目录,my-default.ini重命名为my.ini,编辑my.ini文件内容,如下:

    [mysql]
    port = 3306
    default-character-set=utf8
    [mysqld]
    port = 3306
    basedir=C:\\software\\mysql-5.7.14-winx64
    datadir=C:\\software\\mysql-5.7.14-winx64\\data
    max_connections=200
    character-set-server=utf8
    default-storage-engine=INNODB
    sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
    

    在这里插入图片描述

2.2.2、初始化mysql并指定超级用户密码
  • 启动命令行,将目录切换到mysql安装目录的bin目录下。在命令行执行命令:结果如下图所示,记住下图中红框位置这个 临时密码。

    mysqld --initialize --user=mysql --console
    

    在这里插入图片描述

2.2.3、安装mysql服务
  • 执行mysqld --install命令,返回结果:Service successfully installed。表示成功,如下图:

在这里插入图片描述

  • 快捷键win+r,执行services.msc查看服务,看看mysql服务是否已出现,如下图表示ok。
    在这里插入图片描述
2.2.4、启动mysql服务
  • 执行如下命令,启动mysql服务,如下图:

    net start mysql 
    

在这里插入图片描述

  • 如果发生错误:执行mysqld -remove命令移除mysql服务,然后执行mysqld --install重新安装,最后在执行net start mysql启动服务。

    #移除mysql服务
    mysqld -remove
    #重新安装
    mysqld --install
    #启动服务
    net start mysql
    
  • 如果无法启动程序,丢失MSVCR120.dll,这是微软官网的链接 https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=40784 下载自己对应的版本,安装,一般可以解决。
    在这里插入图片描述

2.2.5、登录用户管理及密码修改
  • 输入命令行如下命令,利用之前的临时密码输入即可登录数据库

    mysql -u root -p
    

    在这里插入图片描述

  • 修改root用户密码

    SET PASSWORD = PASSWORD('123456');
    update mysql.user set Host='%' where HOST='localhost' and User='root';
    flush privileges;
    

    在这里插入图片描述

2.2.6、开启远程访问
  • 查询所有数据库,进入mysql库,查询用户。
    说明:host为localhost表示只允许本地登录,host为ip表示为只允许指定ip用户登录,host为%为允许任意ip用户登录

    #查询所有数据库
    show databases;
    #进入mysql库
    use mysql;
    #查询用户
    select user,host from user; 
    

在这里插入图片描述

  • 新建允许远程链接mysql数据库的test用户

    #表示创建一个登录名为test,密码为123456供任意ip访问的用户(%可用具体ip替代)
    grant all on *.* to test@'%' identified by '123456' with grant option;
    flush privileges;
    

在这里插入图片描述

三、192.168.132.36服务器上安装mysql(

  • 安装步骤与192.168.132.35主服务器上安装mysql()步骤相同。

四、mysql互为主从配置

4.1、修改两台服务器上mysql配置文件

4.1.1、修改192.168.132.35服务器上mysql配置
  • 修改192.168.132.35主服务器my.ini文件中的配置,在[mysqld]部分增加如下内容,(server_id的值要与192.168.132.36主服务器不同,其他内容相同,binlog_do_db的值为需要进行主从备份的数据库)

    init_connect='SET NAMES utf-8'
    innodb_buffer_pool_size=64M
    innodb_flush_log_at_trx_commit=1
    innodb_lock_wait_timeout=120
    innodb_log_buffer_size=4M
    innodb_log_file_size=256M
    interactive_timeout=120
    join_buffer_size=2M
    key_buffer_size=32M
    max_allowed_packet=16M
    max_heap_table_size=64M
    myisam_max_sort_file_size=64G
    myisam_sort_buffer_size=32M
    read_buffer_size=512kb
    read_rnd_buffer_size=4M
    skip_external_locking=on
    sort_buffer_size=256kb
    table_open_cache=256
    thread_cache_size=16
    tmp_table_size=64M
    wait_timeout=120
    server_id =1
    log_bin=C:\\software\\mysql-5.7.14-winx64\\mysqlbin
    #binlog记录内容的方式,记录被操作的每一行
    binlog_format=ROW
    #减少记录日志的内容,只记录受影响的列
    binlog_row_image=minimal
    #指定需要复制的数据库名为db_test,如果备份多个数据库,重复设置这个选项即可
    binlog_do_db=db_test
    #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
    binlog_ignore_db=mysql
    binlog_ignore_db=performance_schema
    binlog_ignore_db=information_schema
    binlog_ignore_db=sys
    # 这个参数要加上,否则不会给更新的记录些到二进制文件里(未测试)
    log-slave-updates=1
    #开启慢查询日志
    slow_query_log=1
    slow_query_log_file=C:\\software\\mysql-5.7.14-winx64\\mysql_slow_query.log
    long_query_time=10
    log_error=C:\\software\\mysql-5.7.14-winx64\\mysql_error.log
    
  • 重启192.168.132.35主服务器MySQL服务
    在这里插入图片描述

4.1.2、修改192.168.132.36服务器上mysql配置
  • 修改192.168.132.36主服务器my.ini文件中的配置,在[mysqld]部分增加如下内容,(server_id 的值要与192.168.132.35主服务器不同,其他内容相同,binlog_do_db的值为需要进行主从备份的数据库)

    init_connect='SET NAMES utf-8'
    innodb_buffer_pool_size=64M
    innodb_flush_log_at_trx_commit=1
    innodb_lock_wait_timeout=120
    innodb_log_buffer_size=4M
    innodb_log_file_size=256M
    interactive_timeout=120
    join_buffer_size=2M
    key_buffer_size=32M
    max_allowed_packet=16M
    max_heap_table_size=64M
    myisam_max_sort_file_size=64G
    myisam_sort_buffer_size=32M
    read_buffer_size=512kb
    read_rnd_buffer_size=4M
    skip_external_locking=on
    sort_buffer_size=256kb
    table_open_cache=256
    thread_cache_size=16
    tmp_table_size=64M
    wait_timeout=120
    server_id =2
    log_bin=C:\\software\\mysql-5.7.14-winx64\\mysqlbin
    #binlog记录内容的方式,记录被操作的每一行
    binlog_format=ROW
    #减少记录日志的内容,只记录受影响的列
    binlog_row_image=minimal
    #指定需要复制的数据库名为db_test,如果备份多个数据库,重复设置这个选项即可
    binlog_do_db=db_test
    #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
    binlog_ignore_db=mysql
    binlog_ignore_db=performance_schema
    binlog_ignore_db=information_schema
    binlog_ignore_db=sys
    # 这个参数要加上,否则不会给更新的记录些到二进制文件里(未测试)
    log-slave-updates=1
    #开启慢查询日志
    slow_query_log=1
    slow_query_log_file=C:\\software\\mysql-5.7.14-winx64\\mysql_slow_query.log
    long_query_time=10
    log_error=C:\\software\\mysql-5.7.14-winx64\\mysql_error.log
    
  • 如果是复制的192.168.132.35服务器到192.168.132.36服务器,需要修改192.168.132.36服务器C:\software\mysql-5.7.14-winx64\data\auto.conf文件中的值,需要与192.168.132.35服务器中的值不同。
    一定要修改值不一样,此处大坑。。。。。。

  • 重启192.168.132.36从服务器MySQL服务
    在这里插入图片描述

4.2、创建两台服务器Replication用户

4.2.1、192.168.132.35服务器上创建Replication用户
  • 创建Repl用户

    grant all on *.* to 'repl'@'%' identified by '123456' with grant option;
    grant replication slave on *.* to 'repl'@'%';
    grant replication client,replication slave on *.* to 'repl'@'%' identified by '123456';
    flush privileges;
    

在这里插入图片描述

4.2.2、192.168.132.36服务器上创建Replication用户
  • 创建Repl用户

    grant all on *.* to 'repl'@'%' identified by '123456' with grant option;
    grant replication slave on *.* to 'repl'@'%';
    grant replication client,replication slave on *.* to 'repl'@'%' identified by '123456';
    flush privileges;
    

在这里插入图片描述

4.3、查看两台服务器的mysql bin log位置

4.3.1、查看192.168.132.35服务器上mysql bin log位置
  • 查看mysql bin log位置,执行如下命令:

    #锁定表,禁止所有操作。防止bin log位置发生变化
    flush tables with read lock;
    #查看Master1服务器上bin log位置
    show master status;
    #解除两台主机mysql table的锁定
    unlock tables;
    

    在这里插入图片描述

  • 查询出的mysql bin log位置在步骤4.4步骤中会使用。

4.3.2、查看192.168.132.36服务器上mysql bin log位置
  • 查看mysql bin log位置,执行如下命令:
    #锁定表,禁止所有操作。防止bin log位置发生变化
    flush tables with read lock;
    #查看Master1服务器上bin log位置
    show master status;
    #解除两台主机mysql table的锁定
    unlock tables;
    
    在这里插入图片描述
  • 查询出的mysql bin log位置在步骤4.4步骤中会使用。

4.4、设置两台服务器的Slave Replication

4.4.1、设置192.168.132.35服务器上Slave Replication
  • 设置Slave Replication,执行如下命令:

    stop slave;
    change master to master_host = '192.168.136.36', master_user = 'repl', 
    master_password = '123456', master_port = 3306, master_connect_retry=30, master_log_file = 'mysqlbin.000009',master_log_pos = 154; 
    start slave;
    

    在这里插入图片描述

4.4.2、设置192.168.132.36服务器上Slave Replication
  • 设置Slave Replication,执行如下命令:

    stop slave;
    change master to master_host = '192.168.136.35', master_user = 'repl', 
    master_password = '123456', master_port = 3306, master_connect_retry=30, master_log_file = 'mysqlbin.000009',master_log_pos = 154; 
    start slave;
    

    在这里插入图片描述

4.5、查看两台主机是否设置成功

4.5.1、查看192.168.132.35服务器是否设置成功
  • 查看是否设置成功,执行如下命令:

    show slave status\G;
    
  • 其中Slave_IO_Running:Yes Slave_SQL_Running:Yes表示主从搭建已成功,如下图:
    在这里插入图片描述

4.5.2、查看192.168.132.36服务器是否设置成功
  • 查看是否设置成功,执行如下命令:

    show slave status\G;
    
  • 其中Slave_IO_Running:Yes Slave_SQL_Running:Yes表示主从搭建已成功,如下图:
    在这里插入图片描述

五、mysql互为主从测试

5.1、192.168.132.35服务器创建数据库,并在192.168.132.36服务器上查看是否有192.168.132.35服务器创建的数据库

  • 192.168.132.35服务器创建db_test数据库,创建表t_user并新增一条数据,如下图:
    在这里插入图片描述

  • 192.168.132.36服务器上查看db_test数据库、t_user表及表中数据,如下图:
    在这里插入图片描述

  • 192.168.132.35、192.168.132.36服务器把创建的数据库删除,如下图:

5.2、192.168.132.36服务器创建数据库,并在192.168.132.35服务器上查看是否有192.168.132.36服务器创建的数据库 - 192.168.132.35、192.168.132.36服务器把创建的数据库删除,如下图:

  • 删除192.168.132.36服务器上创建的db_test数据库,如下图:
    在这里插入图片描述

  • 刷新192.168.132.35服务器上数据库,其中db_test库也同步删除了,如下图:
    在这里插入图片描述

六、报错解决

6.1、报错slave failed to initialize relay log info structure from the repository

  • 解决方式

    #重置slave
    reset slave
    

6.2、报错Could not find first log file name in binary log index file

  • 解决方式

    #停止报错机器的slave
    stop slave;
    #执行flush logs;因为刷新日志file的位置会+1,使2台机器的mysqld-bin的相同
    flush logs;
    #在启动slave
    start slave;
    

6.3、报错Client requested master to start replication from position > file size

  • 解决方式

    #查看bin log位置
    show master status;
    #重新执行 slave replication
    stop slave;
    change master to master_host = '192.168.136.36', master_user = 'repl', 
    master_password = '123456', master_port = 3306, master_connect_retry=30, master_log_file = 'mysqlbin.000009',master_log_pos = 154; 
    start slave;
    

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

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

相关文章

电力工作记录仪、智能安全帽、智能布控球助力智能电网建设

电力行业的建设和发展是国家经济发展的重要支撑,而智能电网作为电力系统的重要组成部分,它的安全高效运行关乎到整个电力系统乃至民生的稳定和安全。为了加快国家经济的发展以及满足人们对电力的需求和用电可靠性的要求,国家早在十二规划中就…

操作系统(三)| 进程管理上 进程状态 同步 互斥

目录 1 进程和程序区别 2 进程状态 2.1 进程的5种基本状态 2.2 进程状态之间转换 2.3 七状态模型 3 进程描述 3.1 进程控制块 PCB 3.2 进程块组织方式 4 进程控制 5 进程同步 互斥 5.1 区分进程互斥和同步 5.2 核心方案 5.3 其他方案 方案1 设置锁变量 方案2 严…

数据湖的概念、发展背景和价值

数据湖是一个集中化的存储系统,旨在以低成本、大容量的方式,无需预先对数据进行结构化处理,存储各种结构化和非结构化数据。以下是数据湖概念、发展背景和价值的详细介绍。 数据湖概念 数据湖的概念源自于对传统数据仓库的补充。传统数据仓…

AI大爆发的时代,未来的年轻人怎样获得机会和竞争力?

文章目录 引言AI与教育工作者教育资源不平衡 这次,狼真的来了。 引言 AI正迅猛地改变着我们的生活。 根据高盛发布的一份报告,AI有可能取代3亿个全职工作岗位,影响全球18%的工作岗位。在欧美,或许四分之一的工作可以用AI完成。另…

windows排除扫描文件夹

搜索防火墙和网络保护 点击病毒和威胁防护 往下拉,找到排除项 添加排除项

计算机毕业设计 基于SpringBoot的社区物资交易互助平台/系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…

【计算机网络学习之路】Windows下的socket编程

文章目录 前言Windows下的socket编程1.预备工作2. socket编程 结束语 前言 本系列文章是计算机网络学习的笔记,欢迎大佬们阅读,纠错,分享相关知识。希望可以与你共同进步。 本篇文章仅记录Windows下socket编程和Linux的不同,并没…

Lec15 Crash recovery

xv6文件系统实现分为七层,如图所示 File system logging(文件系统日志) 日志驻留在超级块中指定的已知固定位置。 它由一个头块(header block)和一系列更新块的副本(logged block)组成。头块…

关于Unity Time.deltaTime的理解和使用

Unity中的Time.deltaTime是一个表示上一帧到当前帧所用时间的浮点数。 它可以让Unity应用程序能够以平滑的方式在不同的帧率下运行。 要深刻理解Time.deltaTime,首先得了解Unity引擎得工作原理。 Unity引擎以每秒帧数(FPS)的形式运行。 比…

STM32:时钟树原理概要

在一般情况下只要在CubeIDE中将RCC下的高速时钟源设置成晶振,随后在时钟配置中把HCLK设置到最大频率(比如STM32F103的最高频率是72MHZ ),CubeIDE就会帮我们自动调节其它参数到合适的值。这样我们芯片就可以全速运行了。 一、时钟信…

python查找算法_顺序查找

顺序查找(Sequential Search)是一种简单直观的搜索算法,用于在无序数组中查找特定元素。它的基本思想是逐个遍历数组中的元素,直到找到目标元素或遍历完整个数组。本文将介绍顺序查找的基本原理,并通过Python代码进行详…

基于人工大猩猩部队算法优化概率神经网络PNN的分类预测 - 附代码

基于人工大猩猩部队算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于人工大猩猩部队算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于人工大猩猩部队优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&a…

硬盘录像机无法注册到视频监控平台EasyCVR上是什么原因?该如何解决?

视频监控汇聚平台EasyCVR可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安防视频监控的能力,也…

【剑指offer|图解|链表】链表的中间结点 + 链表中倒数第k个结点

🌈个人主页:聆风吟 🔥系列专栏:数据结构、算法模板 🔖少年有梦不应止于心动,更要付诸行动。 文章目录 📋前言一. ⛳️链表的中间结点二. ⛳️链表中倒数第k个结点📝结语 &#x1f4c…

VPX 插座(VITA46)介绍及应用 (简单介绍)

1. VPX 插座的介绍 VPX是VITA(VME International Trade Association, VME国际贸易协会)组织于2007年在其VME总线基础上提出的新一代高速串行总线标准。VPX总线的基本规范、机械结构和总线信号等具体内容均在ANSI/VITA46系列技术规范中定义。VPX就是基于高速串行总线的新一代总线…

【Node.js】大前端技能最通俗易懂的讲解 快速入门必看

目录 1、概述前端工具VSCode安装 2、NodeJS的安装 3、NodeJS了解和快速入门 4、NodeJS实现HttpServer服务 5、NodeJS实现操作MySQL数据库 Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它允许开发者在服务器端执行Node.js是一个基于Chrome V8引擎的Ja…

跳台阶游戏(Python排列组合函数itertools.combinations的应用)

给定台阶总数和两种单次可跳级数,编写自定义函数,计算所有的游戏组合方案数量。 (笔记模板由python脚本于2023年11月19日 19:18:48创建,本篇笔记适合熟悉python自定义函数编写,了解排列组合知识的coder翻阅) 【学习的细节是欢悦的…

(一)pytest自动化测试框架之生成测试报告(mac系统)

前言 我们可以通过pytest-html插件来生成测试报告,但是pytest-html插件生成的测试报告不够美观,逼格也不够高,通过allure生成的测试报告是比较美观的,花里胡哨的,能够提升一个level。 allure官网: Allure…

基于纹理特征的kmeas聚类的图像分割方案

Gabor滤波器简介 在图像处理中,以Dennis Gabor命名的Gabor滤波器是一种用于纹理分析的线性滤波器,本质上是指在分析点或分析区域周围的局部区域内,分析图像中是否存在特定方向的特定频率内容。Gabor滤波器的频率和方向表示被许多当代视觉科学…

美国国家安全实验室员工详细数据在网上泄露

一个从事出于政治动机的攻击的网络犯罪组织破坏了爱达荷国家实验室(INL)的人力资源应用程序,该组织周日在电报上发帖称,已获得该核研究实验室员工的详细信息。 黑客组织 SiegedSec 表示,它已经访问了“数十万用户、员…