MySQL大表优化方案之升级硬件

升级硬件

Scale up,这个不多说了,根据MySQL是CPU密集型还是I/O密集型,通过提升CPU和内存、使用SSD,都能显著提升MySQL性能

读写分离

也是目前常用的优化,从库读主库写,一般不要采用双主或多主引入很多复杂性,尽量采用文中的其他方案来提高性能。同时目前很多拆分的解决方案同时也兼顾考虑了读写分离

缓存

缓存可以发生在这些层次:

  • MySQL内部:在系统调优参数介绍了相关设置
  • 数据访问层:比如MyBatis针对SQL语句做缓存,而Hibernate可以精确到单个记录,这里缓存的对象主要是持久化对象Persistence Object
  • 应用服务层:这里可以通过编程手段对缓存做到更精准的控制和更多的实现策略,这里缓存的对象是数据传输对象Data Transfer Object
  • Web层:针对web页面做缓存
  • 浏览器客户端:用户端的缓存

可以根据实际情况在一个层次或多个层次结合加入缓存。这里重点介绍下服务层的缓存实现,目前主要有两种方式:

  • 直写式(Write Through):在数据写入数据库后,同时更新缓存,维持数据库与缓存的一致性。这也是当前大多数应用缓存框架如Spring Cache的工作方式。这种实现非常简单,同步好,但效率一般。
  • 回写式(Write Back):当有数据要写入数据库时,只会更新缓存,然后异步批量的将缓存数据同步到数据库上。这种实现比较复杂,需要较多的应用逻辑,同时可能会产生数据库与缓存的不同步,但效率非常高。

表分区

MySQL在5.1版引入的分区是一种简单的水平拆分,用户需要在建表的时候加上分区参数,对应用是透明的无需修改代码

对用户来说,分区表是一个独立的逻辑表,但是底层由多个物理子表组成,实现分区的代码实际上是通过对一组底层表的对象封装,但对SQL层来说是一个完全封装底层的黑盒子。MySQL实现分区的方式也意味着索引也是按照分区的子表定义,没有全局索引

MySQL大表优化方案之升级硬件

用户的SQL语句是需要针对分区表做优化,SQL条件中要带上分区条件的列,从而使查询定位到少量的分区上,否则就会扫描全部分区,可以通过EXPLAIN PARTITIONS来查看某条SQL语句会落在那些分区上,从而进行SQL优化,如下图5条记录落在两个分区上:

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/4601.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚重蔚管理团队
上一篇 2018年3月10日 16:35
下一篇 2018年3月10日 16:44

相关推荐

  • 关于宝塔登入。

    宝塔面板是一款非常流行的服务器管理软件,它以可视化界面、功能丰富和操作简便而受到广大网站管理员的喜爱,本指南旨在帮助初学者轻松上手宝塔面板,实现快速部署和管理服务器。 安装宝塔面板 要使用宝塔面板,首…

    2024年7月22日
    00
  • 我来说说使用MySQL如何进行修改wait_timeout参数。

    很多小伙伴在使用MySQL的过程中,并不知道如何进行wait_timeout的参数修改,下面简单的解释一下: 1.修改参数配置文件 vi /etc/my.cnf [mysqld] wait_timeout = 28800 interactive_timeout = 28800 注意这里只需增…

    2024年6月13日
    01
  • 我来分享云服务器如何连接本地mysql。

    通过云服务器的公网IP和端口,使用MySQL客户端工具连接到本地MySQL。 云服务器如何连接本地mysql 随着云计算技术的发展,越来越多的企业和个人选择将数据和应用部署在云服务器上,而在开发和测试过程中,我们经常需…

    2024年7月10日
    01
  • 关于asp的数据库文件怎么打开。

    在ASP中打开两个数据库 ASP(Active Server Pages)是一种动态网页开发技术,它允许开发人员在服务器端执行脚本来生成动态内容,在ASP中,可以使用ADO(ActiveX Data Objects)对象来连接和操作数据库,要在ASP中打…

    2024年6月30日
    01
  • 我来分享香港服务器空间租用如何维护。

    香港服务器空间租用维护需要注意以下几点: ,- 选择合适的机房和服务商,确保机房设备完善、售后服务好。,- 定期备份数据,防止数据丢失。,- 监控服务器性能,及时发现潜在问题并采取相应措施。,- 定期清理服务…

    2024年7月10日
    01
  • 小编教你navicat基本操作。

    Navicat是一款强大的数据库管理工具,它提供图形界面用于轻松管理远程数据库。使用Navicat,我们可以进行连接数据库、操作数据库、导入备份、查询数据、修改用户信息等基本操作。它也支持查看数据库版本和SQL执行计…

    2024年7月5日
    01
  • 我来分享最新版的Percona Server有哪些优点。

    Percona Server是一款开源的、完全免费的MySQL服务器,它由Percona公司开发和维护,Percona Server是MySQL的一个分支,它继承了MySQL的优点,同时也进行了许多改进和优化,使得它在性能、稳定性和安全性等方面都有…

    2024年7月22日
    01
  • PHP操作MySQL的流程

    1.链接数据库 2.选择数据库并设置编码 3.准备SQL语句 4.发生SQL语句到MySQL服务器 5.接收返回的结果集资源 6.解析结果集资源 7.关闭链接资源 流程图:

    2018年3月23日
    0290

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息