mysql中影响数据库性能的因素讲解
关于数据库性能的故事
面试时多多少少会讲到数据库上的事情,“你对数据库的掌握如何?”,什么时候最考验数据库的性能,答应主要方面上讲就是大数据量的读写时,而电商类的大促活动就是考验各自的数据库性能的时候啦。
对于web服务器而言,数据量大时,我们可以简单的通过横向扩展来减少单个服务器的负担,对于数据库服务器来说就没有那么简单了,他们不可能做到轻易的横向扩展,这样也违背了数据库的完整性与一致性的原则,那么我们的数据库架构该如何搭建呢?
对于大促类活动而言,不管是产品多好、策划多成功,如果没有稳定的数据库及服务器环境,则这所谓的一切都将是一场空呀。
数据库架构案例
如图所示,主从服务器之间没有任何主从复制组件,即当主服务器出现了故障,很难进行主服务器的切换,这需要DBA在从服务器中选择数据最新的从服务器将其提升为主服务器并同步其他从服务器,这个过程的时间成本也是非常沉重的。
且过多的从服务器,当业务量大时对主服务器的网卡也是一定的挑战。
我们可以通过对集群的监控信息来了解是什么影响了数据库性能。
答应其实是肯定的,一般情况下主要是QPS与TPS、并发量(同一时间处理的请求的数量,避免和连接数混淆)、磁盘IO、读操作过于高
这里有个建议最好不要在主库上数据备份,起码在大型活动前要取消这类计划、
影响数据库的因素
- sql查询速度
- 服务器硬件
- 网卡流量
- 磁盘IO
超高的QPS和TPS
风险效率底下的SQL(QPS每秒钟处理的查询量)
大量的并发和超高的CPU使用率
风险大量的并发(数据库连接数被占满(max_connections默认100))
风险超高的CPU使用率(因CPU资源耗尽而出现宕机)
磁盘IO
风险磁盘IO性能突然下降(使用更快的磁盘设备)
风险其他大量消耗磁盘性能的计划任务(调整计划任务)
网卡流量
风险网卡IO被占满(1000Mb/8=100MB)
如何避免无法连接数据库的情况
1、减少从服务器的数量
2、进行分级缓存
3、避免使用“select ”进行查询
4、分离业务网络和服务器网络
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程