数据库优化三部曲(1)-主从复制-一蓑烟雨任平生

2023-12-20 18:20

本文主要是介绍数据库优化三部曲(1)-主从复制-一蓑烟雨任平生,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySql(解压包安装)

1. 安装mysql无非两种方法,要么Installer安装包安装,要么zip安装,直接上链接MySql下载
2. Installer这种就不讲了,之前我也一直用这种方法安装的,傻瓜式安装,一直Next下一步,中间除了设置下安装位置和设置密码,其他都不用看的
3. 讲解下zip安装,之前也没用过这种方法安装,所以就摸石头过河走一步算一步,下载完zip文件,我下载的8.0版本的
在这里插入图片描述

4. 解压出来放在你想放的位置,我放在了H盘,然后改名为1
在这里插入图片描述

5. 然后新建一个文件my.ini,然后复制下面的内容放进去
在这里插入图片描述

6. 安装Mysql服务,执行命令mysqld install mysql2,这里取了别名mysql2,因为后面需要一台服务器多个mysql服务,所以先取名mysql2,然后会出现Service successfully installed.这就是成功了,如果报错了,没成功,那就使用管理员身份输入命令就可以了在这里插入图片描述

7. 然后执行下一步:mysqld --initialize,这一步会在你的mysql安装目录下生成data文件,如果没有生成,那肯定是my.ini文件你没使用双斜杠//的原因
在这里插入图片描述

8. 使用net start mysql2 命令启动mysql2服务,关闭服务就是net stop mysql2,我为了演示,先关闭一下mysql2
9.

9. 这样子就启动mysql了,接下来改密码,看网上改密码的方案很多my.ini加配置我没成功,但是找到了一个简单的方法,直接在data目录里面找到xxx.err文件,里面有临时密码
在这里插入图片描述

10. 然后mysql -u root -p,然后回车在这里插入图片描述提示密码错误,但是密码明明对的啊为啥会错呢??当你输入之前电脑装的mysql密码时,神奇的进来了在这里插入图片描述

你执行的是mysql命令,计算机不知道是哪个mysql,所以它会默认找电脑之前装过的mysql,所以价格端口号来区分下mysql数据库就可以了

在这里插入图片描述加个大写-P端口号,这样子,那个err密码就可以使用了,恩,进来了之后,第一步就是改密码,那么复杂的密码改简单好记一些

alter user 'root'@'localhost' identified by '想要设置的密码';

这里注意一点就是那个引号一定要是英文的,不然会报语法错误

同个服务器多个MySql安装

1. 就跟上面安装单个MySql的方法一样,安装第二个Mysql,然后运行就可以了
2. 注意第二个MySql名字一定要改下别名,还有端口号,都需要修改
3. 安装完之后,管理中的服务就是这样的
在这里插入图片描述

MySql读写分离,主从复制

技术原理

为什么?

进行中的项目,有大量的第三方数据频繁的写入,影响了读的效率。通过读写分离,可以实现读锁和写锁的竞争。读锁和写锁可以具体网上找其他资源了解。
怎么做?
  1. 主从复制:主数据库有写操作,从数据库自动同步。从数据库通过I/O线程去请求主数据库的binlog日志文件(二进制日志,包含SQL的增删改查等,用来做备份恢复等),并写到中继日志中,SQL线程会读取中继日志,并解析成具体操作同步数据到从数据库。
  2. 读写分离:数据库层面:主数据库复制写,从数据库复制读。软件(代码)层面:通过读写分离中间间,比如MyCat、shardingsphere等实现。

实现方法

1. 配置主数据库
服务器ID命名,主从配置

server-id=1
log_bin=master-bin
log_bin_index=master-bin.index
binlog_do_db=test

然后重启mysql服务在这里插入图片描述创建一个用户,并赋予replication slave权限。
创建用户可以

CREATE USER 'pig'@'%' IDENTIFIED BY '123456';

这样子创建,也可以直接用客户端创建
在这里插入图片描述
查看主数据库状态

show master status;

在这里插入图片描述

  1. 配置从数据库
    服务命名,主从配置
server-id=2
relay-log=slave-relay-bin
relay-log-index=slave-relay-bin.index

连接master主机

change master to master_host='127.0.0.1',master_port=3506,master_user='pig',master_password='123456',master_log_file='master-bin.000004',master_log_pos=388;

启动同步

start slave;

关闭同步

STOP slave;

查看slave信息

show slave status

在这里插入图片描述
在这里插入图片描述
这俩必须都是YES,一个是读取主数据库日志,一个是执行日志

下面说两种情况

第一种IO_RUNNING是CONNECT的话说明权限问题(当然网上说的答案很多,pos问题,网络问题,反正我是把权限全打开了就好了)

第二种SQL_RUNNING是NO,那样的话就执行下面的代码

slave stop;
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
slave start;

执行完就OK了
测试一下 结果
在主数据库中插入一些数据

在这里插入图片描述在这里插入图片描述
主数据库增加后,从数据库也跟着增加了,测试很完美
然后删除主数据库

在这里插入图片描述

总结问题:

问:如果从库的Slave_IO_Running为NO。
答:要么给权限,要么执行

show variables like 'server_id';
set global server_id=2;
slave start;

问:如果从库的slave_sql_running为NO。
答:执行下面代码

slave stop;
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
slave start;

问:从改主断开
答:主库锁定表:主改从必改,从改主不改

flush tables with read lock;
show master status;

下一期讲解,项目中的读写分离使用,一个项目使用两个数据库,需要使用MyCat,读写分开极大的减小了数据库的压力,主从复制只是铺垫,下篇博客见

在这里插入图片描述

这篇关于数据库优化三部曲(1)-主从复制-一蓑烟雨任平生的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/516991

相关文章

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

Python内存优化的实战技巧分享

《Python内存优化的实战技巧分享》Python作为一门解释型语言,虽然在开发效率上有着显著优势,但在执行效率方面往往被诟病,然而,通过合理的内存优化策略,我们可以让Python程序的运行速度提升3... 目录前言python内存管理机制引用计数机制垃圾回收机制内存泄漏的常见原因1. 循环引用2. 全局变

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据