数据库优化三部曲(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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

DM8数据库安装后配置

1 前言 在上篇文章中,我们已经成功将库装好。在安装完成后,为了能够更好地满足应用需求和保障系统的安全稳定运行,通常需要进行一些基本的配置。下面是一些常见的配置项: 数据库服务注册:默认包含14个功能模块,将这些模块注册成服务后,可以更好的启动和管理这些功能;基本的实例参数配置:契合应用场景和发挥系统的最大性能;备份:有备无患;… 2 注册实例服务 注册了实例服务后,可以使用系统服务管理,