MySQL8.0 一主二从

news2025/1/3 3:23:42

1. 系统环境

cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)

192.168.183.137     mysql-master
192.168.183.153     mysql-slave-1
192.168.183.154     mysql-slave-2

# 关闭SELINUX
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
setenforce 0

# 关闭防火墙
systemctl stop firewalld
systemctl disable firewalld

2. 安装MySQL

三台机器均执行

wget  https://dev.mysql.com/get/mysql80-community-release-el7-7.noarch.rpm
yum -y install  mysql80-community-release-el7-7.noarch.rpm
yum clean all && yum makecache
yum -y  install mysql-community-server
systemctl start mysqld
systemctl enable mysqld

# 查看root密码
grep 'temporary password' /var/log/mysqld.log
mysql -uroot -ppassword

# 修改root密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;

3. mysql-master配置文件修改

vim /etc/my.cnf
# 加入以下内容
server_id=137      # server_id需要保证唯一性,不可与其他从服务器相同 如果为0会拒绝所有从服务器连接
log-bin=mysql-bin  # 设置同步的binary log二进制日志文件名前缀,默认是binlog
binlog_ignore_db = information_schema # 不需要同步的数据库
binlog_ignore_db = performance_schema # 不需要同步的数据库
innodb_flush_log_at_trx_commit=1  # 我们每次事务的结束都会触发Log Thread 将log buffer中的数据写入文件并通知文件系统同步文件。这个设置是最安全的设置,能够保证不论是MySQL Crash 还是OS Crash或者是主机断电都不会丢失任何已经提交的数据。

4. mysql-slave-1配置文件修改

vim /etc/my.cnf
# 加入以下内容
server_id=153      
log-bin=mysql-bin 
binlog_ignore_db = information_schema 
binlog_ignore_db = performance_schema 
innodb_flush_log_at_trx_commit=1  

5. mysql-slave-2配置文件修改

vim /etc/my.cnf
# 加入以下内容
server_id=154     
log-bin=mysql-bin 
binlog_ignore_db = information_schema 
binlog_ignore_db = performance_schema 
innodb_flush_log_at_trx_commit=1  

修改完成之后全部重启systemctl restart mysqld

6. 主库创建复制用户

mysql -uroot -ppassworn

# 创建同步账户master节点 执行

mysql> CREATE USER slave@'%' IDENTIFIED BY 'QAZqaz1234@';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'slave'@'%'WITH GRANT OPTION;
mysql> CHANGE MASTER TO GET_MASTER_PUBLIC_KEY=1;
mysql> FLUSH PRIVILEGES;
mysql> SHOW MASTER STATUS;

mysql> show master status;
+------------------+----------+--------------+---------------------------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB                      | Executed_Gtid_Set |
+------------------+----------+--------------+---------------------------------------+-------------------+
| mysql-bin.000001 |      873 |              | information_schema,performance_schema |                   |
+------------------+----------+--------------+---------------------------------------+-------------------+

7. 配置从库

mysql -uroot -ppassworn

# slave-1和slave-2都是同样的操作
mysql> change master to
master_host='192.168.183.137',master_user='slave',master_password='QAZqaz1234@',
master_log_file='master-bin.000001',master_log_pos=873;

# 启动同步
mysql> START SLAVE;
mysql> FLUSH PRIVILEGES;

mysql> SHOW SLAVE STATUS\G

Slave_IO_Running: Connecting,

报错:Error connecting to source 'slave@192.168.183.137:3306'. This was attempt 5/86400, with a delay of 60 seconds between attempts. Message: Authentication plugin 'caching_sha2_password' reported error: Authentication requires secure connection.

发生这个问题的原因是在 mysql 8.0 以后,caching_sha2_password是默认的身份验证插件,而不是以往的mysql_native_password。在 MySQL Command Line 工具下修改 mysql 的默认身份验证插件即可。

登录主库

ALTER USER slave@'%' IDENTIFIED WITH mysql_native_password BY 'QAZqaz1234@';

FLUSH PRIVILEGES;

然后从库重新同步

# slave-1和slave-2都是同样的操作
mysql> STOP SLAVE;

mysql> change master to
master_host='192.168.183.137',master_user='slave',master_password='QAZqaz1234@',
master_log_file='master-bin.000001',master_log_pos=1323;

# 启动同步
mysql> RESET SLAVE;
mysql> START SLAVE;
mysql> FLUSH PRIVILEGES;

再次查看同步状况可以看到已经成功:

mysql> SHOW SLAVE STATUS\G

8. 测试

在master节点上执行SQL语句

create database db_test;
show databases;

在从库上面查看

在master的db_test库里面创建表

use db_test;
# 创建一个my_user表:
CREATE TABLE `my_user` (
  `id` tinyint(4) NOT NULL AUTO_INCREMENT,
  `account` varchar(255) DEFAULT NULL,
  `passwd` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
);

# 插入数据:
INSERT INTO `my_user` VALUES ('1', 'admin', 'admin');
INSERT INTO `my_user` VALUES ('2', 'pu', '12345');
INSERT INTO `my_user` VALUES ('3', 'system', 'system');

# 查看插入数据
select * from db_test.my_user;

到从库上都能查到则说明没问题。

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

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

相关文章

基于SpringBoot的幼儿园管理系统 免费获取源码

项目源码获取方式放在文章末尾处 项目技术 数据库:Mysql5.7 数据表:16张 开发语言:Java(jdk1.8) 开发工具:idea 前端技术:html 后端技术:SpringBoot 功能简介 项目获取关键字:幼儿园 该…

React-css-in-js技术

​🌈个人主页:前端青山 🔥系列专栏:React篇 🔖人终将被年少不可得之物困其一生 依旧青山,本期给大家带来React篇专栏内容:React-css-in-js技术 目录 1、简介 2、定义样式与使用 3、样式继承 4、属性传递 1、简介 …

买婴儿洗衣机怎么选择?四大绝佳好用婴儿洗衣机分享

幼龄时期的宝宝的衣物,是比较需要注意的时候。可能一不注意宝宝穿在身上就会有不适宜症状发生。所以宝妈们真的要随时观察,然后在宝宝洗衣服的这上面多下点功夫,不要让宝宝受到这种无谓的伤害。小婴儿的抵抗力比我们差很多。有些细菌、病毒可…

IP地址怎么实现https

IP可以申请SSL证书。可以解决企业需要对IP实现https加密的需求,一张证书可以支持同时绑定多个IP。 IP证书有两种级别:基础级IP SSL证书和标准企业级IP SSL证书。 基础型SSL证书只需要10-30分钟即可颁发,企业型需要1-3个工作日即可颁发。 企…

Suno,属于音乐的ChatGPT时刻来临

AI绘画 AI视频我们见过了,现如今AI都能生成一首音乐,包括编曲,演唱,而且仅需几秒的时间便可创作出两分钟的完整歌曲 相信关注苏音的很大一部分都是从获取编曲或者混音插件来的,现如今AI却能帮你几秒生成曲子 今天就带…

deepspeed笔记

文章目录 一、deepspeed是什么?二、能训多大的模型,耗时如何?三、RLHF训练流程四、通信策略 一、deepspeed是什么? 传统的深度学习,模型训练并行,是将模型参数复制多份到多张GPU上,只将数据拆分…

C语言结课实战项目_贪吃蛇小游戏

目录 最终实现效果: 实现基本的功能: 根据游戏进程解释代码: 游戏初始化: 首先进入游戏,我们应该将窗口名称改为 “贪吃蛇” 并将光标隐藏掉。再在中间打印游戏信息。 之后我们要把地图打印出来: 然后…

数据可视化插件echarts【前端】

数据可视化插件echarts【前端】 前言版权开源推荐数据可视化插件echarts一、如何使用1.1 下载1.2 找到js文件1.3 入门使用1.4 我的使用 二、前后端交互:入门demo2.1 前端htmljs 2.2 后端entitycontrollerservicemapper 三、前后端交互:动态数据3.1 前端j…

书生·浦语大模型全链路开源体系-第6课

书生浦语大模型全链路开源体系-第6课 书生浦语大模型全链路开源体系-第6课相关资源Lagent & AgentLego 智能体应用搭建环境准备创建虚拟环境安装LMDeploy安装 Lagent安装 AgentLego Lagent 轻量级智能体框架使用 LMDeploy 部署启动并使用 Lagent Web Demo使用自定义工具获取…

mysql的mgr集群的网络不可达之后脑裂的问题

此时主节点上的dml和ddl操作都会挂死,由于脑裂问题,无法判断谁是主谁是备,所以节点无法写操作。 此时需要手动介入处理: mysql> show variables like %group_replication_member_expel_timeout%; ---------------------------…

Java上机实验报告(7)

实验 (7) 项目名称:组件及事件处理-注册页面 一、 实验报告内容一般包括以下几个内容: 实验项目名称 实验7 组件及事件处理-注册页面 实验目的和要求 本实验的目的: 本实验的目的是让学生掌握常用的组件类JButton&am…

空气源热泵电控系统部分控制功能的逻辑

空气源热泵的电控系统,是一台空气源热泵设备的大脑,电控系统逻辑的合理性、执行的精准性,直接决定设备运行的稳定、能效高低、运行寿命。 控制功能 (1)压缩机防频繁起停 压缩机再次启动间隔时间为3分钟,即压…

果园系统养殖游戏喂养偷菜种植浇水养成小程序功能介绍

以下是上述功能介绍的重写版本: 装扮 使用丰富的材料,为您的房屋增添独特魅力,展现个性化装饰风格。 土地升级 投入不同数量的材料,提升房屋与土地的品质,打造独一无二的庄园。 日志 通过日志记录,清…

Flask实战

from flask import Flask appFlask(__name__)点击Flask同时点击键盘ctrl即可查看Flask的默认初始化函数 def __init__(self,import_name: str,static_url_path: str | None None,static_folder: str | os.PathLike[str] | None "static",static_host: str | None …

LeetCode-31-下一个排列问题

题目说明 实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。 如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。 必须原地修改,只允许使用额外常数空间。…

考研日常记录

由于实在太无聊了 , 所以记录以下考研备考日常 , 增加一点成就感 , 获得一点前进动力。 2024.4.18 周四 课程情况: 无课 时间规划: 上午:休息 下午: 事项耗时进度备注写作业1h复习英语单词…

SayNav: 利用大语言模型在未知环境中导航

论文标题:SayNav: Grounding Large Language Models for Dynamic Planning to Navigation in New Environments 论文地址:https://arxiv.org/pdf/2309.04077.pdf 项目地址:https://www.sri.com/ics/computer-vision/saynav SayNav介绍 SayNa…

ExpandableListView可扩展列表视图,可折叠列表视图

目录 1. XML代码 2. ExpandableListView的使用 3. ExpandableListAdapter的使用 4. 数据观察者的使用 5. 案例代码一览 ExpandableListView(可扩展/可折叠列表视图)是一种多功能的高级控件,每个子项都可以展开一个孙子列表。点击一个分组…

科研基础与工具(笔记)

​ 免责申明: 本文内容只是学习笔记,不代表个人观点,希望各位看官自行甄别 参考文献 科研基础与工具(YouTube) 专业名词 影响因子(Impact Factor),一般是特指SCI的影响因子&#…

Qt实现Mysql数据库的连接,查询,修改,删除,增加功能

Qt实现Mysql数据库的连接,查询,修改,删除,增加功能 安装Mysql数据库,QtCreator Mysql选择Mysql Server 8.1版本安装。 Mysql Server 8.1安装过程 1.首先添加网络服务权限: WinR键输入compmgmt.msc进入…