Mysql主从复制和Mysql高可用以及负载均衡配置
需要先配置MySQL主从复制,然后再在主MySQL服务器上配置MySQL Router。以下是详细说明和步骤:
1. 为什么需要先配置MySQL主从复制?
MySQL主从复制是MySQL高可用性和负载均衡的基础,通过将数据从主服务器实时同步到从服务器,确保数据一致性和可用性。在配置MySQL Router之前,需要确保主从复制环境正常工作,这样MySQL Router才能根据主从架构进行读写分离和负载均衡。
2. MySQL主从复制配置步骤
以下是配置MySQL主从复制的主要步骤,参考:
(1)主服务器配置
- 开启二进制日志:修改主服务器的配置文件(如
my.cnf),确保以下设置:[mysqld] server-id = 1 log-bin = mysql-bin binlog-format = ROW binlog-do-db = your_database_name - 创建复制用户:
CREATE USER 'repl'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%'; FLUSH PRIVILEGES; - 记录主服务器状态:
记录SHOW MASTER STATUS;File和Position值,用于从服务器配置。
(2)从服务器配置
- 修改配置文件:设置
server-id和relay-log:[mysqld] server-id = 2 relay-log = mysql-relay-bin - 配置主服务器信息:
CHANGE MASTER TO MASTER_HOST='master_ip', MASTER_USER='repl', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', -- 主服务器记录的File值 MASTER_LOG_POS=701; -- 主服务器记录的Position值 - 启动复制:
检查START SLAVE; SHOW SLAVE STATUS \G;Slave_IO_Running和Slave_SQL_Running状态是否为Yes。
(3)验证主从同步
在主服务器执行写操作,然后查看从服务器是否同步:
SHOW SLAVE STATUS \G;
3. MySQL Router配置步骤
MySQL Router是一个轻量级中间件,用于实现读写分离、负载均衡和故障转移。以下是配置步骤,参考:
(1)安装MySQL Router
根据操作系统选择安装方式,例如在Ubuntu上:
sudo apt-get install mysql-router
(2)配置MySQL Router
- 生成配置文件:
mysqlrouter --bootstrap root@localhost:3306 <<EOF mysqlrouter --user=mysqlrouter EOF - 编辑配置文件(
mysqlrouter.conf):- 添加主服务器和从服务器信息:
[routing:writer] bind_address = 127.0.0.1 port = 6446 destinations = writer1:3306 [routing:reader] bind_address = 127.0.0.1 port = 6447 destinations = reader1:3306,reader2:3306 - 配置读写分离策略:
[default] routing_strategy = round-robin
- 添加主服务器和从服务器信息:
(3)启动MySQL Router
mysqlrouter &
(4)测试连接
- 连接到主服务器:
mysql -h 127.0.0.1 -P 6446 -u your_username -p - 连接到从服务器:
mysql -h 127.0.0.1 -P 6447 -u your_username -p
4. 配置顺序总结
- 先配置MySQL主从复制:确保主从服务器之间的数据同步正常。
- 再配置MySQL Router:在主服务器上安装并配置MySQL Router,实现读写分离和负载均衡。
相关文章:
Mysql主从复制和Mysql高可用以及负载均衡配置
需要先配置MySQL主从复制,然后再在主MySQL服务器上配置MySQL Router。以下是详细说明和步骤: 1. 为什么需要先配置MySQL主从复制? MySQL主从复制是MySQL高可用性和负载均衡的基础,通过将数据从主服务器实时同步到从服务器&#…...
c#中使用时间戳转换器
在C#中,时间戳转换器通常用于将时间戳(通常是一个表示自某一特定时间点(如1970年1月1日UTC)以来的毫秒数的长整型值)转换为DateTime对象,或者将DateTime对象转换回时间戳。以下是几种实现这一功能的方法: 1. 使用DateTime的构造函数 将时间戳转换为DateTime long tim…...
杂项知识笔记搜集
1.pygame pygame可以画出来图形界面,pygame Python仓库 PyGame游戏编程_游戏程序设计csdn-CSDN博客 2.V4L2库 V4L2是Linux上的Camera采集器的框架 Video for Linux ,是从Linux2.1版本开始支持的。HDMI视频采集卡采集到的视频通过USB3.0输出࿰…...
rust语言match模式匹配涉及转移所有权Error Case
struct S{data:String, }//注意:因为String默认是移动语义,从而决定结构体S也是移动语义,可采用(1)或(2)两种方法解决编译错误;关键思路:放弃获取结构体S的字段data的所有权,改为借用。fn process(s_ref:&a…...
golang从入门到做牛马:第十一篇-Go语言变量作用域:变量的“生活圈”
在Go语言中,变量的作用域决定了它在程序中的可见性和生命周期。理解变量的作用域对于编写清晰、高效的代码至关重要。Go语言中的变量可以在三个主要地方声明:函数内、函数外和函数定义中。接下来,让我们深入探讨局部变量、全局变量和形式参数的作用域。 局部变量:函数内的“…...
【Linux】37.网络版本计算器
文章目录 1. Log.hpp-日志记录器2. Daemon.hpp-守护进程工具3. Protocol.hpp-通信协议解析器4. ServerCal.hpp-计算器服务处理器5. Socket.hpp-Socket通信封装类6. TcpServer.hpp-TCP服务器框架7. ClientCal.cc-计算器客户端8. ServerCal.cc-计算器服务器9. 代码时序1. 服务器启…...
linux安装Mariadb10.5并修改端口
首先配置yum源 进入下方的文件进行配置 vim /etc/yum.repos.d/MariaDB.repo填写下方内容 [mariadb]name MariaDBbaseurl https:///mirrors.aliyun.com/mariadb/yum/10.5/centos8-amd64/gpgkeyhttps:///mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDBmodule_hotfixes…...
从Windows到ARM Linux:Qt程序的交叉编译与移植指南
引言 在嵌入式开发中,我们经常需要将桌面端开发的Qt程序部署到ARM架构的Linux设备。本文详细介绍如何将Windows平台开发的Qt程序,通过Linux虚拟机交叉编译为ARM架构可执行文件的完整过程 环境准备 需要特别注意的是,对于CentOS 7 默认支持…...
【微信小程序】uniapp开发微信小程序
uniapp开发微信小程序 1、上拉加载 下拉刷新 import { onReachBottom, onPullDownRefresh } from dcloudio/uni-app;配置允许下拉刷新: {"path" : "pages/pet/pet","style" : {"navigationBarTitleText" : ""…...
多视图几何--结构恢复--三角测量
三角测量 1. 核心公式推导 假设两个相机的投影矩阵为 P P P 和 P ′ P P′,对应的匹配图像点(同名点)为 ( u , v ) (u, v) (u,v) 和 ( u ′ , v ′ ) (u, v) (u′,v′),目标是求解三维点 X [ X x , X y , X z , 1 ] T X [X_x, X_y, X_z, 1]^T X…...
【Linux三剑客】awk命令使用
AWK 编程语言中的变量 AWK 提供了许多可在模式和操作中使用的内置变量。最常用的变量是 - NR - 表示当前记录(行)号 NF - 表示输入记录中的字段总数。 $0 - 整个当前记录。 $1, $2, $3, … - 当前记录中的第一个、第二个、第三个…字段。 查找passwd中…...
Python CATIA二次开发实战:CATIA产品号批量同步文件名工具开发
引言 在汽车/航空制造领域,CATIA文件的结构化管理直接影响着PLM系统数据一致性。笔者近期开发的增强型产品号同步工具,成功解决了工程实践中文件名与产品名称不同步的痛点问题。本文将从技术实现、功能亮点、应用场景三个维度进行深度解析。 一、技术方…...
我的两个医学数据分析技术思路
我的两个医学数据分析技术思路 从临床上获得的或者公共数据库数据这种属于观察性研究,是对临床诊疗过程中自然产生的数据进行分析而获得疾病发生发展的规律等研究成果。再细分,可以分为独立危险因素鉴定和预测模型构建两种。 独立危险因素鉴定是一直以…...
操作系统之进程状态、优先级和切换与调度
文章目录 1. 进程状态1.1 课本名词提炼1.2 运行&阻塞&挂起1.2.1 运行1.2.2 阻塞1.2.3 挂起 1.3 理解内核链表1.4 Linux中的内核解释1.5 进程状态的查看1.6 Z(zombie)——僵尸进程1.6.1 创建僵尸进程1.6.2 僵尸进程的危害 1.7 孤儿进程 2. 进程优先级2.1 基本概念2.2 查…...
[免费]微信小程序(图书馆)自习室座位预约管理系统(SpringBoot后端+Vue管理端)(高级版)【论文+源码+SQL脚本】
大家好,我是java1234_小锋老师,看到一个不错的微信小程序(图书馆)自习室座位预约管理系统(SpringBoot后端Vue管理端)(高级版),分享下哈。 项目视频演示 【免费】微信小程序(图书馆)自习室座位预约管理系统(SpringBoot后端Vue管理端)(高级版…...
你使用过哪些 Java 并发工具类?
你的回答(口语化,面试场景) 面试官:你使用过哪些 Java 并发工具类? 你: 好的,我结合项目经验来说说常用的并发工具类: CountDownLatch 作用:等所有线程就绪后再触发任务…...
模板方法模式的C++实现示例
核心思想 模板方法设计模式是一种行为设计模式,它定义了一个算法的框架,并将某些步骤的具体实现延迟到子类中。通过这种方式,模板方法模式允许子类在不改变算法结构的情况下重新定义算法的某些步骤。 模板方法模式的核心在于: …...
国产编辑器EverEdit - 脚本(解锁文本编辑的无限可能)
1 脚本 1.1 应用场景 脚本是一种功能扩展代码,用于提供一些编辑器通用功能提供不了的功能,帮助用户在特定工作场景下提高工作效率,几乎所有主流的编辑器、IDE都支持脚本。 EverEdit的脚本支持js(语法与javascript类似)、VBScript两种编程…...
越早越好!8 个反直觉的金钱真相|金钱心理学
很多人都追求财富自由,但成功的人少之又少。 这可能是因为,人们往往忽略了一些金钱的真相和常识。 01 金钱常识 & 真相 为了构建健康的金钱观,我读了一本有点反直觉,有点像鸡汤,但都是财富真相的书。 来自 Morg…...
linux docker相关指令
1、镜像操作 0)、搜索:docker search 镜像名称 1)、拉取:docker pull 2)、推送:docker push 3)、查看:docker images 4)、查看所有镜像ID:d…...
DDR内存信号完整性设计与电源噪声分析
1. DDR内存接口设计的信号完整性挑战演进在2000年代初期的DDR时代,信号完整性工程师面临的主要挑战是确保数据信号(DQ)与选通信号(DQS)之间的时序对齐。当时的接口速率普遍低于400Mbps,时序裕量相对宽松&am…...
2025届最火的十大降重复率工具推荐
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当前阶段,部分域内有着AIGC被滥用的状况,这毫无疑问增添了运营成本以…...
用DevC++和OpenCV 2.4.10写个图像处理小工具:从环境搭建到第一个窗口程序
用DevC和OpenCV 2.4.10打造图像处理工具:从零到实战 在编程学习的道路上,没有什么比"动手做出一个实际可用的工具"更能激发学习动力了。本文将带你用DevC和OpenCV 2.4.10,从环境搭建开始,一步步创建一个能实际处理图像的…...
创业公司如何通过Taotoken以可控成本快速验证AI产品创意
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 创业公司如何通过Taotoken以可控成本快速验证AI产品创意 对于初创团队而言,验证一个AI产品创意的核心在于“快”和“可…...
不只是连线:用立创EDA做PCB布局时,这5个提升电路板可靠性的细节你注意了吗?
不只是连线:用立创EDA做PCB布局时,这5个提升电路板可靠性的细节你注意了吗? 在电子设计领域,PCB布局的质量往往决定了产品的最终表现。许多工程师能够完成基本的电路连接,却容易忽视那些看似微小却至关重要的设计细节。…...
YOLOv8 室内行人跌倒数据集信息表
YOLOv8 室内行人跌倒数据集信息表 数据集概述 项目内容数据集名称YOLOv8 室内行人跌倒数据集总图像数量9,262 张应用场景跌倒检测、公共安全监控、老年人护理、智能安防目标类别2 类:stand(站立)、fall(跌倒)标注格式…...
Vim/Neovim集成AI编程助手Neural:提升开发效率的本地化实践
1. 项目概述:在Vim/Neovim中集成AI编程助手 如果你和我一样,是个常年泡在终端和编辑器里的开发者,那你肯定对Vim或Neovim有着特殊的感情。它们高效、可定制,几乎成了我们思维的外延。但有时候,面对一些重复性的代码模…...
如何用QVina实现20倍分子对接加速:3步构建高效药物筛选平台
如何用QVina实现20倍分子对接加速:3步构建高效药物筛选平台 【免费下载链接】qvina Accurately speed up AutoDock Vina 项目地址: https://gitcode.com/gh_mirrors/qv/qvina 如果你正在进行大规模药物筛选或分子对接计算,等待时间过长可能成为研…...
Asp.net Mvc教学: LINQ相关的几大分类的使用率-由Deepseek产生
基于当前(2026年).NET开发生态的实际情况,这五大方法的使用率呈现出非常明显的两极分化趋势。 简单直接地回答:使用率高的只有两个,其他三个使用率极低,属于特定场景工具。 以下是具体的排名与解析…...
Awesome-Xamarin快速入门:10分钟掌握最实用的Xamarin开发工具
Awesome-Xamarin快速入门:10分钟掌握最实用的Xamarin开发工具 【免费下载链接】awesome-xamarin A collection of interesting libraries/tools for Xamarin mobile projects 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-xamarin 想要快速提升Xam…...
