当前位置: 首页 > article >正文

Mysql读写分离(1)-服务器的设置(主从复制)

1.简介

随着网站访问和请求量的增加,单台数据库服务器的连接已耗尽,会出现连接请求还在等待,或是数据库服务器崩溃等现象,这时候我们考虑如何减少数据库的连接,可以通过优化代码、使用缓存、数据库读写分离等方式解决此问题。

什么是读写分离:将数据库的读、写操作分别作用到不同的数据库(不同物理机)上。 

适用场景:读操作远大于写操作,包含大量复杂统计、离线计算等任务(比如定时按各维度对数据进行统计分析,或者结算佣金等) 

系统环境: linux centos 5.6 两台

mysql版本: 5.6

Mysql主从同步的现实: 

       1、Master库将变更记录到binlog中 

       2、Slave将master的binlog拷贝到它的relay log(中继日志)中

       3、slave重做中继日志中的事件

2.详细设置

==2-1主库操作==

1、在my.ini文件的[mysqld]节中添加如下配置项: 

server-id=1                 #分配server_id的时候需要保证唯一

log-bin=master-bin.log

sync_binlog=1

binlog-do-db=test_db  #指定对名称为test_db的数据库记录二进制日志

binlog-ignore-db = mysql #指定不对名称为mysql的数据库记录二进制日志 

binlog_format = mixed #binlog日志格式

expire_logs_days = 7  #超过7天的binlog删除###

2、使用root用户登录主库mysql,为同步操作创建一个用户,从库通过该用户同步主库数据

3、对待同步用户授权:

GRANT REPLICATION SLAVE ON *.* to 'test'@'%' identified by '123';

建立一个用户名是test的用户,认证密码是123。’test‘@'%' 表示允许在任意ip连接。拥有主从复制权限。*.* 表示所有数据库

其他例子:

grant select,insert,update,delete on db.* to test1@"192.169.0.122" Identified by "abc";

增加一个用户test1密码为abc,让他只能允许在192.169.0.122登录,并对db数据库下的所有数据表拥有插入、修改、删除的权限

4、重启主库mysql服务,并再次登录后查看主库状态:

show master status;

 如图:

记住下面的 master-bin.000002 和 120 这是从库要同步的文件和同步的位置 

好了,主库的配置完成了,现在进行从库的配置

3从库操作

1、登录从库的服务器,在my.ini文件的[mysqld]节中添加如下配置项:

server-id=2log-bin=myslave-bin.logsync_binlog=1replicate-do-db = test_db   #复制名称为test_db的数据库 ,如果不设置,默认复制全部数据库                                                         replicate-ignore-db = mysql   #不需要(忽略)复制名称为mysql的数据库                                            replicate-ignore-db = information_schema    #不需要(忽略)复制名称为information_schema的数据库

2、使用root用户登录从库mysql,修改从库的master信息

change master to master_host='192.168.1.109',master_user='test',master_password='123',master_log_file='mysql-bin.000002',master_log_pos=120;

留意上面参数的值:

master_host   主库的ip

master_log_file  上面提到的主库的日志名称

master_log_pos  上面提到的同步位置

千万不要搞错了,搞错了就会配置失败。

3、启动从库:start slave;

4、查看从库状态:show slave status;下面红色框框里面的两个参数都是Yes,则说明主从配置成功!

如果没有出现YES,请参考 Last_IO_Error: 这行的信息,参考下面的常见问题配置

4.测试

我们在主库里

然后马上到从库里查找(感觉应该会有几毫秒的延迟,这里不知道怎样保证事务安全,这个拓展到下篇文章再说了)

5.常见问题

5.1 不能连接的问题

主库关闭防火墙

或者用iptables 单独允许3306连接

然后从库重启mysql服务

5.2 出现 The slave I/O thread stops because master and slave have equal MySQL server UUIDs

首先停止mysql服务

找到auto.cnf的位置,然后把它删掉

启动就可以

参考:Mysql修改server uuid的方法分享_Mysql_脚本之家

5.3 如果出现类似字样  “Got fatal error 1236 from master when reading data from binary log: 'Could not find first log file n”

stop slave;
reset slave;
start slave;

5.4 如何重新配置主从

stop slave;
reset master;

6.参考

Mysql读写分离实现的三种方式_mysql有没有做读写分离。怎么实现的-CSDN博客

相关文章:

Mysql读写分离(1)-服务器的设置(主从复制)

1.简介 随着网站访问和请求量的增加,单台数据库服务器的连接已耗尽,会出现连接请求还在等待,或是数据库服务器崩溃等现象,这时候我们考虑如何减少数据库的连接,可以通过优化代码、使用缓存、数据库读写分离等方式解决…...

STM32F103ZET6移植FATFS文件系统教程(W25Q32)

一、FATFS核心特性 跨平台支持‌ 支持FAT12/FAT16/FAT32格式,兼容Windows文件系统‌; 采用标准C语言编写,代码量小且支持RTOS‌。 配置灵活性‌ 通过宏定义实现功能裁剪,例如: FF_FS_READONLY:设为1时禁…...

STM32 模块化开发实战指南:系列介绍

本文是《STM32 模块化开发实战指南》系列的导读篇,旨在介绍整个系列的写作目的、适用读者、技术路径和每一篇的主题规划。适合从事 STM32、裸机或 RTOS 嵌入式开发的个人开发者、初创工程师或企业项目团队。 为什么要写这个系列? 在嵌入式开发中,很多人刚开始都是从点亮一个…...

AF3 create_alignment_db_sharded脚本create_shard函数解读

AlphaFold3 create_alignment_db_sharded 脚本在源代码的scripts/alignment_db_scripts文件夹下。 该脚本中的 create_shard 函数的功能是将一部分链(shard_files)中的所有对齐文件写入一个 .db 文件,并返回这些链的索引信息(字节…...

【Python语言基础】21、Python标准库

文章目录 1. 标准库1.1 标准库构成及特点1.2 常见分类和模块1.3 标准库使用 1. 标准库 Python 标准库就像是 Python 自带的 “百宝箱”,里面装了各种各样已经写好的工具,你在编程的时候可以直接拿来用,不用自己再费劲去编写。 什么是标准库 …...

数据库脱裤

假设你已经getshell 找到mysql账号密码。 网站要连接mysql,就需要把mysql的账号密码保存在一个php文件中,类似config.php、common.inc.php等,在shell中,读取这些文件,找到其中信息即可 下面是一些常见平台的配置文…...

信刻电子档案蓝光光盘刻录安全检测长期归档

信刻一直致力于为档案馆、各行业档案部门,提供跨网数据交换、电子档案数据磁光异质备份归档解决方案。所研制的电子档案光盘智能长期归档系统,满足国产环境下”刻、管、存、检、用”全生命周期管理应用需求,能够提供一份离线归档、一份近线存…...

vue3中,element-plus中el-input的v-model和value的用法示例

el-input的v-model&#xff0c;邦定响应式变量 <el-col :span"6"><el-form-item label"检验类别" prop"verifyType"><el-input v-model"applyAllInfo.applyBasicInfo.verifyTypeName" readonly /></el-form-item…...

文章记单词 | 第33篇(六级)

一&#xff0c;单词释义 poison [ˈpɔɪzn] n. 毒药&#xff1b;毒物&#xff1b;有害的思想&#xff08;或心情等&#xff09;&#xff1b;vt. 毒死&#xff1b;毒害&#xff1b;下毒&#xff1b;在… 中放毒&#xff1b;污染&#xff1b;adj. 有毒的justification [ˌdʒʌ…...

深度学习算法:从基础到实践

简介 深度学习作为人工智能领域的一个重要分支&#xff0c;近年来在多个领域取得了显著的成就。本文将从基础概念出发&#xff0c;探讨深度学习算法的核心原理&#xff0c;并介绍一些实际应用案例。 深度学习算法的核心概念 深度学习算法基于人工神经网络&#xff0c;通过构…...

L2-052 吉利矩阵分

L2-052 吉利矩阵 - 团体程序设计天梯赛-练习集 所有元素为非负整数&#xff0c;且各行各列的元素和都等于 7 的 33 方阵称为“吉利矩阵”&#xff0c;因为这样的矩阵一共有 666 种。 本题就请你统计一下&#xff0c;把 7 换成任何一个 [2,9] 区间内的正整数 L&#xff0c;把矩…...

计算机网络中各种物理量的单位总结

在计算机网络中&#xff0c;数据速率的单位容易混淆&#xff0c;以下是清晰总结&#xff1a; 一、基本单位区分 比特&#xff08;bit&#xff09;与字节&#xff08;Byte&#xff09; 小写 b 表示 比特&#xff08;bit&#xff09;&#xff0c;是数据传输的基本单位。 大写 B…...

Solidity私有函数和私有变量区别,私有变量可以被访问吗

web3面试题 私有函数和私有变量区别&#xff0c;私有变量可以被访问吗 ChatGPT said: 在 Web3 开发&#xff0c;尤其是使用 Solidity 编写智能合约时&#xff0c;关于私有函数和私有变量的区别是常见的面试题。下面是详细解析&#xff1a; ✅ 私有函数&#xff08;Private Fu…...

解决JSON格式数据大小写问题,以及@JsonProperty 和@JSONField序列化的区别

1、JsonProperty注解方式 JsonProperty注解是annotation包下的一个注解&#xff0c;可以通过value属性定义注解修饰的属性名称&#xff0c;如果你用的是JsonProperty注解&#xff0c;那么你千万不要用JSONObject.toJSONString(实体)去转json&#xff0c;可能很多人在这里就蒙蔽…...

Python正则表达式有哪些常用匹配字符?

处理文本数据时&#xff0c;我们经常需要查找、提取或替换特定模式的字符串。这时候正则表达式就成了程序员最强大的武器之一。今天我们就来详细聊聊Python中那些最常用的正则表达式字符和它们的实际用法。 为什么要学正则表达式&#xff1f; 假设你遇到这些场景&#xff1a;…...

List、Set集合通过Stream流求和

目录 一、泛型为Integer、Long、Double、BigDecimal求和 二、泛型为实体类 对单个属性求和 对多个属性分别分组求和 并返回聚合后的对象 多字段乘积求和&#xff08;基本数据类型&#xff09; 多字段乘积求和&#xff08;BigDecimal&#xff09; 对对象中的多个字段求和…...

Linux:Makefile

编译器gcc 使用方式&#xff1a;gcc [ 选项 ] 要编译的⽂件 [ 选项 ] [ ⽬标⽂件 ] 编译分为以下几个步骤&#xff1a; 1.预处理(进⾏宏替换) 预处理功能主要包括宏定义,⽂件包含,条件编译,去注释等。 预处理指令是以#号开头的代码⾏。 实例: gcc –E hello.c –o hello…...

基于双闭环PID控制器的永磁同步电机控制系统匝间故障Simulink仿真

欢迎微♥关注“电击小子程高兴的MATLAB小屋”获取巨额优惠 1.模型简介 本仿真模型基于MATLAB/Simulink&#xff08;版本MATLAB 2013Rb&#xff09;软件。建议采用matlab2013 Rb及以上版本打开。&#xff08;若需要其他版本可联系代为转换&#xff0c;高于该版本的matlab均可正…...

硬件电路设计之51单片机(2)

声明&#xff1a;绘制原理图和PCB的软件为嘉立创EDA。根据B站尚硅谷嵌入式之原理图&PCB设计教程学习所作个人用笔记。 目录 一、原理图详解 1、TypeC接口 &#xff08;1&#xff09;TypeC接口介绍 &#xff08;2&#xff09;TypeC原理图 2、5V转3.3V 3、单片机电源开…...

从零开始学习PX4源码20(遥控器模式切换如何执行)

目录 文章目录 目录摘要1.用到的消息和主题2.遥控器切换模式代码流程摘要 本节主要学习PX4的手动遥控器切换模式,具体是如何实现的,具体改变了哪些变量,和模式管理有什么联系。 1.用到的消息和主题 1.行为请求消息:ActionRequest.msg ///时间信息 uint64 timestamp # t…...

SpringAI+DeepSeek大模型应用开发——1 AI概述

AI领域常用词汇 LLM&#xff08;LargeLanguage Model&#xff0c;大语言模型&#xff09; 能理解和生成自然语言的巨型AI模型&#xff0c;通过海量文本训练。例子&#xff1a;GPT-4、Claude、DeepSeek、文心一言、通义干问。 G&#xff08;Generative&#xff09;生成式: 根据上…...

经济指标学习(一)

系列文章目录 文章目录 系列文章目录1、市净率**一、定义与计算****二、核心意义****三、应用场景****四、局限性****五、分类与衍生指标****总结** 2、市销率**一、定义与计算****二、核心意义****三、优缺点分析****四、适用场景****五、与其他指标的对比****六、实际应用案例…...

理解 results = model(source, stream=True) 的工作原理和优势

1. 核心概念解析 (1) streamTrue 的作用 生成器模式&#xff1a;当处理视频或图像序列时&#xff0c;streamTrue 会将结果包装成一个 生成器&#xff08;Generator&#xff09;&#xff0c;逐帧生成 Results 对象&#xff0c;而不是一次性返回所有结果。内存优化&#xff1a;…...

国内互联网大厂推出的分布式数据库 的详细对比,涵盖架构、性能、适用场景、核心技术等维度

以下是 国内互联网大厂推出的分布式数据库 的详细对比&#xff0c;涵盖架构、性能、适用场景、核心技术等维度&#xff1a; 一、主流分布式数据库列表 大厂数据库名称类型适用场景发布时间腾讯云TDSQL分布式HTAP金融、电商、游戏、政企2010年阿里云OceanBase分布式HTAP银行核…...

解释`new`关键字的执行过程,并手动实现一个`myNew`函数。

在 JavaScript 中&#xff0c;new 关键字用于创建一个用户定义的对象实例。它的执行过程分为以下步骤&#xff1a; new 关键字的执行过程 创建空对象&#xff1a; 创建一个新的空对象&#xff0c;其 [[Prototype]]&#xff08;即 __proto__&#xff09;指向构造函数的 prototy…...

Android 项目配置文件解释

Android 项目配置文件解释 目录 Android 项目配置文件解释1. `plugins` 块2. `android` 块3. `dependencies` 块为什么需要 JDK 和 Kotlin1. plugins 块 plugins {id com.android.applicationid org.jetbrains.kotlin.android }id com.android.application:应用 Android 应用…...

亚马逊热销变维权?5步搭建跨境产品的安全防火墙

“产品热卖&#xff0c;引来维权”——这已经悄然成为越来越多跨境卖家的“热销烦恼”。曾经拼品拼量&#xff0c;如今却要步步谨慎。商标侵权、专利投诉、图片盗用……这些问题一旦发生&#xff0c;轻则下架、账号被限&#xff0c;重则冻结资金甚至封店。 别让“热销”变“受…...

C语言——分支语句

在现实生活中&#xff0c;我们经常会遇到作出选择和判断的时候&#xff0c;在C语言中也同样要面临作出选择和判断的时候&#xff0c;所以今天&#xff0c;就让我们一起来了解一下&#xff0c;C语言是如何作出选择判断的。 目录 1.何为语句&#xff1f; 2.if语句 2.1 if语句的…...

绿盟二面面试题

5000篇网安资料库https://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247486065&idx2&snb30ade8200e842743339d428f414475e&chksmc0e4732df793fa3bf39a6eab17cc0ed0fca5f0e4c979ce64bd112762def9ee7cf0112a7e76af&scene21#wechat_redirect 1. 原理深度&…...

deepseek生成流程图

目录 Mermaid流程图需求询问框架交互显示流程图markdown在线网站 可能会出现的问题语法报错 在职场中&#xff0c;借助AI生成图表是提升效率的重要技能&#xff0c;本篇我们讲解如何使用deepseek生成流程图 Mermaid流程图 需求 学习太差劲了&#xff0c;我想要一个比较好的学…...