Mysql集群
备注:
本人资历很浅,说的不对话,万望各位前辈不要计较,
另关于环形的问题,我在后面的评论给予回复,
其实环形,解决多地域问题比较好的选择
关于配置步骤我重新整理了一下(主从AND环形)的配置步骤
在我博客中,有兴趣的朋友可以看一下,
http://my.oschina.net/u/1246814/blog/267518
多谢大家的指导.
比如 我有主的1台mysql服务器,俩从服务服务器 外加一个负载均衡器(如果把负载均衡器非常简单的来说话其实就DNS的转发,非常简单来说,其实 IP的轮换嘛)
我读数据的也就(查询)数据 也就(Select)语句时候,我只是在 仨台从服务器中读取数据
主服务器负责(增,删,改)这个一系列操作
顺便唠叨一下, 为啥 Select 我们建仨服务器或者多个呢?
因为距统计,大概B/S架构70%以上的操作都是以查为主(说白了就是展示嘛)
我们执行了DML语句那么负载均衡器,
就会把请求转发到主mysql服务器上,
这里有个问题?
我们已经向主服务器插入数据,或者删除数据,或者更新了数据,
那么是不是意味从服务里数据也应该发生变化呢
是的,从服务器肯定要发生变化的,不然就出现问题,
比如说,我删除了一个用户,
我查询一下被删除的用户, 丫的发现这个用户压根就没被删除,这不是搞笑了嘛,
那么就有了主从配置一说
主从原理:mysql中有一种日志叫做bin日志(二进制日志),
这个日志会记录下所有对MYSQL进行修改的SQL语句。当向主服务器执行SQL语句时,这条SQL语句会被传递到从服务器上再执行一遍。
说白了,就是Bin日志记录下Dml语句,直接到从服务器执行执行一遍相同的Dml操作,这个方式是以二进制,所有效率很好
至于什么时候用主从
1. 备份(如果数据库出现问题,马上再顶上)
2.优化(分流 读写分离)
Look看图
如果是Dml语句其实也可以直接访问主数据库,不必经过负载均衡器,那么这块从
话说回来哈, 负载均衡其实说白了吧,就是dns轮换,IP轮换嘛
如果可以话,其实我们自己也可以相对简单实现的,但这要分情况哈,
我提一个思路, 以MVC为例子 我粗狂简单的举一下列子,
1.在父类Model中对用户请求的sql语句进行分类。
1.1dml语句(update,insert,delelte)
1.2select语句
1.3dcl语句(数据控制语句)
1.4dtl语句(数据事务语句 )
1.5ddl语句(数据定义语句 )
2.我就以常用的dml 与select 语句为列子并拿3个台mysql服务器1台主mysql 2台从Mysql 与Linux系统为例子
对用户请求数据库的Sql指令进行进行统一分类,管理
主服务器IP: 192.168.0.1
从服务器IP: 192.168.0.2
从服务器IP: 192.168.0.2
3. 对用sql指令分析
如果是dml直接连接 192.168.0.1这台服务器
如果是select语句 怎么办呢?
1.我们首先要确定一个件事情要判断两台从服务器的负载大小
我们肯定要把请求发到负载比较小的服务器上是吧
那么我用socket用连接分别连接两台服务器,搞个类似远程控制客服端,
并利用top指令,对两台服务器的CPU内存等一些负载数据进行获取,
然后通过一些计算与比较最后把查询请求连接其中一个从服务器上。
然后就over
回归正题
关于Mysql环形结构也就mysql服务器互相为主从关系
虽然根据有关平台统计,B/S架构的平台70%以上都是都Select为主
那么如果我这个平台,就是(增,删,该)非常多,非常频繁怎么办呢?
如果是主从配置,那么我处理dml语句的就一台服务器,这不够嘛,这样主从服务器的缺点就暴露出来了
那么mysql的环形结构配置就能解决这样类似问题
原理也是利用bin日志来做
现在3个mysql服务器
我们随便向其中任何一台服务服务器执行dml语句,
那么Bin日志记录下Dml语句,
直接到其他服务器执行执行一遍相同的Dml语句操作
look图
完结

本文探讨了Docker中的优化MySQL内存使用量。 它讨论了监视技术(Docker统计,性能架构,外部工具)和配置策略。 其中包括Docker内存限制,交换和cgroups

本文介绍了MySQL的“无法打开共享库”错误。 该问题源于MySQL无法找到必要的共享库(.SO/.DLL文件)。解决方案涉及通过系统软件包M验证库安装

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

本文比较使用/不使用PhpMyAdmin的Podman容器直接在Linux上安装MySQL。 它详细介绍了每种方法的安装步骤,强调了Podman在孤立,可移植性和可重复性方面的优势,还

本文提供了SQLite的全面概述,SQLite是一个独立的,无服务器的关系数据库。 它详细介绍了SQLite的优势(简单,可移植性,易用性)和缺点(并发限制,可伸缩性挑战)。 c

本指南展示了使用自制在MacOS上安装和管理多个MySQL版本。 它强调使用自制装置隔离安装,以防止冲突。 本文详细详细介绍了安装,起始/停止服务和最佳PRA

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

Dreamweaver CS6
视觉化网页开发工具