返回顶部
首页 > 资讯 > 数据库 >优化MySQL 还是使用缓存?
  • 194
分享到

优化MySQL 还是使用缓存?

mysql缓存 2022-05-28 04:05:13 194人浏览 薄情痞子
摘要

  今天我想对一个Greenfield项目上可以采用的各种性能优化策略作个对比。换言之,该项目没有之前决策强加给它的各种约束限制,也还没有被优化过。   具体来说,我想比较的两种优化策略是优化Mysql和缓存

  今天我想对一个Greenfield项目上可以采用的各种性能优化策略作个对比。换言之,该项目没有之前决策强加给它的各种约束限制,也还没有被优化过。

  具体来说,我想比较的两种优化策略是优化Mysql缓存。提前指出,这些优化是正交的,唯一让你选择其中一者而不是另一者的原因是他们都耗费了资源,即开发时间。

 优化mysql

  优化Mysql时,一般会先查看发送给mysql的查询语句,然后运行explain命令。稍加审查后很常见的做法是增加索引或者对模式做一些调整。

  优点

  1、一个经过优化的查询对于所有使用应用的用户来说都是快速的。因为索引通过对数复杂度的速度来检索数据(又名分制,正如你搜索一个电话簿一样,逐步缩小搜索范围),而且随着数据量的递增也能维持良好的性能。对一个未经索引化的查询的结果做缓存随着数据的增长有时候则可能会表现得更差。随着数据的增长,那些未命中缓存的用户可能会得到很糟糕的体验,这样的应用是不可用的。

  2、优化MySQL不需要担心缓存失效或者缓存数据过期的问题。

  3、优化MySQL可以简化技术架构,在开发环境下复制和工作会更加容易。

  缺点

  1、有一些查询不能光通过索引得到性能上的改善,可能还需要改变模式,在某些情况下这对于一些应用可能会很麻烦。

  2、有些模式的更改可能用于反规范化(数据备份)。尽管对于DBA来说,这是一项常用的技术,它需要所有权以确保所有的地方都是由应用程序更新,或需要安装触发器来保证这种变化。

  3、一些优化手段可能是MySQL所特有的。也就是说,如果底层软件被移植到多个数据库上工作,那么很难确保除了增加索引外一些更复杂的优化技术可以通用。

 使用缓存

  这种优化需要人来分析应用的实际情况,然后将处理代价昂贵的部分从MySQL中剥离出来用第三方缓存替代,比如memcached或Redis

  优点

  1、缓存对于一些MySql自身很难优化的查询来说会工作地很好,比如大规模的聚合或者分组的查询。

  2、缓存对于提高系统的吞吐率来说可能是个不错的方案。比如对于多人同时访问应用时响应速度很慢的情况。

  3、缓存可能更容易构建在另一个应用之上。比如:你的应用可能是另一个用MySQL存储数据的软件包的前端,而要对这个软件包做任何数据库方面的改动都非常难。

  缺点

  1、如果数据对外提供多种存取范式(例如,在不同的页面上用不同的形式展示),那么让缓存过期或者更新可能会很难,同时/或者可能需要容忍已过期的数据。一个可行的替代方案是设计一套更加精细的缓存机制,当然它也有缺点,即多次获取缓存会增加时延。

  2、缓存一个产生代价昂贵的对象对于那些未命中缓存的用户(见优化MySQL的优势#1)而言可能会产生潜在的性能差异。一些好的性能实践表明你应该尽量缩小用户之间的差异性,而不仅仅是平均化(缓存倾向于这么做)。

  3、幼稚的缓存实现无力应对一些微妙的漏洞,比如雪崩效应。就在上周我帮助了一个人,他的数据库服务器被多个试图同时再生同样缓存内容的用户请求冲垮。正确的策略是引入一定级别的来将缓存再生的请求序列化。

 总结

  一般情况下,我会建议用户先对MySQL进行优化,因为这是我认为开始阶段最合适的解决方案。但长期来看,大部分应用都会有一些用例需要一定程度上同时实现以上这些方案。

  原文链接: Morgan Tocker   翻译: 伯乐在线 - 高磊

您可能感兴趣的文档:

--结束END--

本文标题: 优化MySQL 还是使用缓存?

本文链接: https://lsjlt.com/news/9383.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 优化MySQL 还是使用缓存?
      今天我想对一个Greenfield项目上可以采用的各种性能优化策略作个对比。换言之,该项目没有之前决策强加给它的各种约束限制,也还没有被优化过。   具体来说,我想比较的两种优化策略是优化MySQL和缓存...
    99+
    2022-05-28
    mysql 缓存
  • MySQL优化(4):查询缓存
    查询缓存: MySQL提供的数据缓存QueryCache,用于缓存SELECT查询的结果 默认不开启,需要在配置文件中开启缓存(my.ini/my.cnf) 在[mysqld]段中,修改query_cache_type完成...
    99+
    2018-07-13
    MySQL优化(4):查询缓存
  • ASP对象缓存:如何利用编程算法优化缓存使用?
    在ASP.NET中,对象缓存是一种非常有用的技术,它可以在服务器端缓存已经计算出的数据或对象,以便在后续请求中快速访问。这样可以显著提高应用程序的性能和响应速度。但是,如果不正确使用对象缓存,会导致应用程序的性能下降甚至崩溃。因此,我们需...
    99+
    2023-06-24
    对象 编程算法 缓存
  • MySQL查询缓存优化示例详析
    目录一、概述二、查询优化内容1、查询缓存的原理2、查询缓存的优缺点3、不能应用查询缓存的内容4、查询缓存相关的服务器变量5、SELECT语句的缓存控制6、查询缓存相关的状态变量7、查询的优化的检查路线8、命中率和内存使用...
    99+
    2024-04-02
  • Android编程使用缓存优化ListView的方法
    本文实例讲述了Android编程使用缓存优化ListView的方法。分享给大家供大家参考,具体如下: ListView调用Adapter的getView方法获取每一个Item布...
    99+
    2022-06-06
    方法 listview 缓存 Android
  • MySQL查询缓存优化的示例分析
    小编给大家分享一下MySQL查询缓存优化的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MySQL查询缓存优化1 概述2...
    99+
    2024-04-02
  • 使用redis缓存的优势
    今天就跟大家聊聊有关使用redis缓存的优势,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。redis(全称:Remote Dictionary Se...
    99+
    2024-04-02
  • 在 Windows 上使用 Django,如何优化缓存机制?
    Django是一个流行的Python Web框架,它提供了各种功能和工具来开发高效的Web应用程序。其中一个关键的功能就是缓存机制,它可以大大提高Web应用程序的性能和响应速度。在本文中,我们将讨论如何在Windows上使用Django并...
    99+
    2023-10-23
    缓存 django windows
  • 如何使用php函数来优化缓存机制?
    引言:在开发网站时,为了提高性能和访问速度,缓存机制是非常重要的。PHP内置了一些函数和扩展来帮助我们实现缓存功能。本文将介绍如何使用PHP函数来优化缓存机制,并提供具体的代码示例。一、了解缓存机制在开始优化缓存机制之前,首先需要了解缓存的...
    99+
    2023-10-21
    缓存 优化 PHP函数
  • 如何使用 Python 缓存 API 优化日志系统?
    Python 是一门流行的编程语言,它被广泛地应用于 Web 开发、数据分析、人工智能等领域。在这些应用中,日志系统是非常重要的一环。在大规模系统中,日志系统的性能往往成为瓶颈,这时候就需要使用缓存 API 来优化日志系统。本文将介绍如何使...
    99+
    2023-08-24
    日志 缓存 api
  • 如何实现MySQL底层优化:缓存机制的应用与优化策略
    如何实现MySQL底层优化:缓存机制的应用与优化策略引言:MySQL 是世界上最流行的关系型数据库管理系统之一,广泛应用于各类业务系统中。然而,随着数据量的增长和业务的复杂化,MySQL 在高并发场景下的性能问题越来越显著。为了提升 MyS...
    99+
    2023-11-08
    缓存 MySQL 优化
  • 缓存优化大师课:使用 ASP 页面片段缓存提升网站速度
    ASP 页面片段缓存是一种技术,可将网站的动态部分缓存到静态 HTML 文件中。当用户请求包含缓存片段的页面时,Web 服务器会直接提供缓存文件,从而绕过昂贵的数据库查询和页面处理过程。 ASP 页面片段缓存的好处 提高页面加载速度:缓...
    99+
    2024-04-02
  • 如何使用Java缓存技术优化你的网站?
    在高并发的情况下,网站的性能很容易受到影响,响应时间变慢,甚至出现宕机的情况。而缓存技术是一种常见的优化手段,可以大大提高网站的性能,减轻服务器的负载。本文将介绍如何使用Java缓存技术来优化你的网站。 一、什么是缓存 缓存是一种将计算结...
    99+
    2023-06-19
    缓存 二维码 javascript
  • 编程算法的挑战:如何优化缓存使用?
    在计算机领域,缓存是一种用于提高数据读取速度的技术。缓存可以将访问频繁的数据存储在快速的存储介质中,以提高访问速度。然而,缓存的使用也会带来一些挑战,特别是在编程算法中,如何优化缓存使用就成为了一个重要的问题。 本文将探讨如何在编程算法中...
    99+
    2023-07-02
    leetcode 编程算法 缓存
  • Django项目缓存优化的介绍及具体使用
    这篇文章主要讲解了“Django项目缓存优化的介绍及具体使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Django项目缓存优化的介绍及具体使用”吧!一、为什么要使用缓存大家可以想一下Dj...
    99+
    2023-06-02
  • mysql查询缓存的优缺点是什么
    MySQL查询缓存的优点包括: 提高查询性能:查询缓存可以将经常执行的查询结果缓存起来,减少了数据库的访问压力,提高了查询性能。...
    99+
    2024-05-21
    mysql
  • 如何优化Laravel接口性能?使用PHP缓存是不是一个好选择?
    Laravel 是一个非常流行的 PHP 框架,为开发人员提供了一个快速构建应用程序的平台。由于它的易用性和灵活性,Laravel 已经成为众多开发人员的首选框架。然而,在开发 Laravel 应用程序时,性能问题往往是一个需要关注的问题。...
    99+
    2023-09-27
    缓存 laravel 接口
  • golang怎么使用mysql缓存
    在 go 中使用 mysql 缓存对于提升性能至关重要。可通过第三方库或 mysql 自带的缓存功能实现。第三方库(如 github.com/go-sql-driver/mysql)使用...
    99+
    2024-04-21
    mysql redis git golang
  • Go 日志记录:如何使用缓存优化函数调用?
    在开发过程中,我们经常需要记录日志以便于追踪和调试。Go 语言提供了标准库 log,可以方便地实现日志记录功能。但是,当我们需要频繁地记录相同的日志信息时,过多的日志记录会对性能产生影响。在这种情况下,我们可以使用缓存优化函数调用,以减少...
    99+
    2023-10-17
    日志 函数 缓存
  • 如何实现MySQL底层优化:查询缓存的使用和性能分析
    如何实现MySQL底层优化:查询缓存的使用和性能分析MySQL是一种常用的关系型数据库管理系统,在大数据量的场景下,优化数据库性能是非常重要的。其中,查询缓存是一个可以帮助提高MySQL性能的重要组件。本文将介绍如何使用查询缓存以及如何进行...
    99+
    2023-11-09
    MySQL 优化 查询缓存
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作