mysql监控优化(二)主从复制

复制解决的基本问题是让一台服务器的数据和其他服务器保持同步。一台主服务器的数据可以同步到多台从服务器上。并且从服务器也可以被配置为另外一台服务器的主库。主库和从库之间可以有多种不同的组合方式。

MySQL支持两种复制方案:基于语句的复制(statement-based replication)和基于行的复制(Row-based replication)。基于语句的复制在MySQL3.23就已经存在,它是使用较多的复制方式。基于行的复制是MySQL5.1引入的。这2种复制方式都是通过记录主服务器的二进制日志,并在从服务器进行重放(replay)完成复制。它们都是异步的。也就是说,从服务器上的数据并非都是最新的。

复制通常不会增加主库的开销,主要是启用二进制日志带来的开销,但出于备份戒及时从崩溃中恢复的目的,这些开销是必要的。通过复制可以将读操作指向从库来获得更好的读扩展,但对于写操作,并不适合通过复制来扩展。

1、mysql复制用途

  • 分布数据

MySQL通常不会对带宽造成很大的压力。因此可以在不同的地理位置来分布数据,实现跨机房跨地域的数据分布。

  • 负载均衡

通过MySQL复制可以将读操作分布到多个服务器上,实现对读密集型应用的优化。

  • 备份

复制对备份很有帮助,但是从服务器并不是备份。

  • 高可用性和故障转移

复制可以避免在应用程序中出现MySQL失效。好癿故隓转移能显著的减少停机时间,甚至让用户无感知。

  • 测试MySQL版本升级

一个常见的方法是先把从服务器升级到MySQL新版本,然后用它来测试查询,确保无异常后再升级主服务器

2、案例:客户投诉:修改了xx信息,提示修改成功。再查看还是旧数据。怎么回事?

很有可能是数据库主从延迟造成的

3、MySQL主从延时延时问题如何处理?

1.偶发性延时:控制写入速度,削峰填谷。

2.频发性延时:拆分数据库实现多点写入

3.最后一招:从库磁盘硬件升级为ssd

4、 mysql主从复制的过程是怎样的呢?如下图所示

  3个线程完成复制:

  • 主库1个线程负责记录数据库变更日志
  • 从库1个线程负责拉取主库的变更日志
  • 从库1个线程负责执行主库的变更日志
  • 实现了获取事件和重放事件的解耦,允许异步进行。
  • 复制的瓶颈:主库并行(多线程)写入和从库串行(单线程)写入,会造成主从延迟。

原文地址:https://www.cnblogs.com/mululu/p/9056628.html

时间: 2024-11-10 14:28:39

mysql监控优化(二)主从复制的相关文章

Mysql性能优化(二)--MySQL监控

1.检查监控服务是否正常提供: 命令: mysqladmin -uroot -p密码 -h服务器主机地址 ping 正常应该显示:mysqld is alive 2.获取mysql当前的状态值 mysqladmin -uroot -p密码 -h服务器主机地址 status uptime:服务器启动后的运行时间 Questions: SQL查询数 Threads: 当前连接数 Slow queries:慢查询数 Opens:已经打开的表的数量 Open_table 表示打开过的表数量 Querie

MySql监控优化

MySQL监控 MySQL服务器硬件和OS(操作系统)调优: 1.有足够的物理内存,能将整个InnoDB文件加载到内存里 —— 如果访问的文件在内存里,而不是在磁盘上,InnoDB会快很多. 2.全力避免 Swap 操作 — 交换(swapping)是从磁盘读取数据,所以会很慢. 3.使用电池供电的RAM(Battery-Backed RAM). 4.使用一个高级磁盘阵列 — 最好是 RAID10 或者更高. 5.避免使用RAID5 — 和校验需要确保完整性,开销很高. 6.将你的操作系统和数据

mysql监控脚本二

==========主从状态监控================= export LANG=en_US.UTF-8 # monitor master-slave  监控主从同步 hostip="10.136.13.92" user="root" pass="[email protected]" message="" # 监控主从同步状态 slaveStatus=$(mysql -u${user} -p${pass}  mysq

MySQL性能优化(二):优化数据库的设计

一:数据库的设计数据库命名:数据库名的命名一般和项目的名称保持一致,不要随意的起名字. 数据库编码: 采用utf8mb4而不使用utf8 MySQL 的“utf8”实际上不是真正的UTF-8,真正的UTF-8是每个字符最多四个字节,而MySQL的“utf8”只支持每个字符最多三个字节.MySQL一直没有修复这个 bug,他们在 2010 年发布了一个叫作“utf8mb4”的字符集,绕过了这个问题.MySQL的“utf8mb4”才是真正的“UTF-8”.所有在使用“utf8”的 MySQL和Mar

MySQL性能优化(二)

1.MySQL基础操作 一:MySQL基础操作 1:MySQL表复制 复制表结构 + 复制表数据 create table t3 like t1; --创建一个和t1一样的表,用like(表结构也一样) insert into t3 select * from t1; --t1的数据全部拿过来,注意是表结构一致才select* ,否则选择相应的的字段列插入 create table t1( id int unsigned not null auto_increment primary key,

京东MySQL监控之Zabbix优化、自动化

随着京东业务的飞速发展, MySQL数据库的使用更加普及.服务器量级飞速增长,这对京东MySQL DBA团队的要求也越来越高.监控系统为数据库管理和维护提供了精确的数据依据,是数据库运维人员的千里眼和顺风耳. 准确.及时.有效的监控,能够使运维人员对生产服务系统运行情况了如指掌.通过分析获得的监控信息,判断被监控数据库的运行状态,对可能出现的问题进行预测,可以及时制定出适当的优化方案,从而保证整个系统正常.高效地运行.这也就在很大程度上保证了数据库的安全性,避免了一些不必要的损失.所以,我们有必

MySQL 复制过滤器、监控维护及主从复制的读写分离

MySQL 复制过滤器.监控维护及基于SSL的主从复制 =============================================================================== 概述: 本章将主要介绍MySQL复制中如何过滤,监控维护,以及基于SSL的主从复制,具体内容如下: MySQL 复制过滤器 ·从服务器库级别过滤 MySQL 清理日志:PURGE 复制监控 ·Master ·Slave 如何确定主从节点的数据是否一致 MySQL基于SSL的主从复制(

Linux运维之Shell编程------(一)监控MySQL错误码及主从复制同步异常

Linux运维之Shell编程 一.监控MySQL错误码及主从复制同步异常 题目:监控MySQL主从同步是否异常,如果异常,则发送短信或者邮件给管理员.提示:如果没主从同步环境,可以用下面文本放到文件里读取来模拟:阶段1:开发一个守护进程脚本每30秒实现检测一次.阶段2:如果同步出现如下错误号(1158,1159,1008,1007,1062),则跳过错误.阶段3:请使用数组技术实现上述脚本(获取主从判断及错误号部分) 阶段2: #!/bin/bash#CONTACT='[email prote

性能测试之mysql监控、优化

我们在做性能测试的目的是什么,就是要测出一个系统的瓶颈在哪里,到底是哪里影响了我们系统的性能,找到问题,然后解决它.当然一个系统由很多东西一起组合到一起,应用程序.数据库.服务器.中中间件等等很多东西.那我们测试的时候上面这些东西里面任何一个环节都可能会出问题,都可能会影响我们系统的性能.这篇博客主要讲下mysql数据库咱们在做性能测试的时候应该监控什么东西,又有哪些需要优化的地方. 一.哪些东西会影响mysql的性能? 1.硬件 2.系统配置 3.数据库表结构 4.SQL以及索引 硬件 硬件就