MySQL 调优如何提高 Laravel 性能

mysql配置调优是数据库专业人员和管理员实施的数据库管理的重要组成部分。它的目的是配置数据库以适应其硬件和工作负载。但在数据库管理领域之外,mysql 配置调优的用处很大程度上被忽视了。

我们假设 mysql 调优可以显着影响 web 应用程序的性能。如果我们能够展示mysql调优的价值,我们相信企业和组织可能会热衷于更大规模地结合这种实践。

如何提高 laravel 应用程序性能

通过调优提高应用程序性能最好通过解决以下领域的综合方法来实现:

服务器资源 – cpu、内存、存储软件配置 – linuxnginx、php…数据库管理系统(dbms)配置 – mysql、postgresql优化数据库方案并更改索引优化应用程序 – 代码、查询、架构……

许多经验丰富的开发人员并不将数据库性能调优视为提高应用程序性能的机会,因为他们对此领域知之甚少。他们花费了大量时间来优化代码库,但已经达到了这样的地步:不再为投入的时间和精力带来有价值的结果。我们对 mysql 调优如何对流行开源 web 应用程序的性能产生积极影响的研究旨在向开发人员展示这一事实。

测试方法

我们对 laravel aimeos 的测试程序让我们可以使用种子数据来比较配置前后应用程序的性能。通过首先使用默认配置运行测试,我们获得了有价值的控制结果来与调整后的配置进行比较。

我们使用以下流程来准备和测试每个应用程序:

部署 laravel aimeos。带有数据的种子数据库。为 jmeter 准备测试。运行测试 10 分钟 – 使用 blazemeter 性能测试平台进行 jmeter 测试。调整 mariadb 配置 – 默认配置测试后,我们的设置保持不变,但 mariadb 针对工作负载、服务器资源和数据库大小进行了调整。重新运行测试 – 使用 blazemeter 重复 jmeter 测试以调整配置。

测试期间我们在 github 上发布了 jmeter 测试、mysql 状态和 mysql 变量。

我们查看了哪些指标?

我们在本研究中查看的指标是:

响应时间(延迟)是发送请求并在服务器端处理请求到客户端收到第一个字节之间的时间。这是让您深入了解服务器性能的重要指标。每秒查询数 是衡量数据库服务器每秒执行多少查询的指标。cpu 利用率.

我们收集了cpu 利用率每秒查询数 指标来比较工作负载。

laravel 艾梅奥斯

aimeos laravel 是一个流行的电子商务 web 应用程序框架,用于创建在线商店、市场和 b2b 应用程序。借助 aimeos,用户可以为 laravel 创建 api 优先的电子商务商店,该商店可以扩展以支持超过 10 亿种商品。它有 30 多种语言版本,安装量超过 300,000 次。

测试设置

为了测试 aimeos,我们以 10 个用户开始测试,但由于默认配置无法完成测试,我们不得不减少用户数量。

我们在数据库中植入了 500 mb 数据。
我们的测试时间是10分钟。

我们使用:

安装了 debian 11 作为操作系统的 aws ec2 实例 c5.xlarge,apache 作为网络服务器,mariadb 10.5 设置为默认配置,数据库大小 500 mb。

mysql配置

aimeos laravel 使用的配置如下:

laravel aimeos 500mb 的调整配置

query_cache_type=1query_cache_size=134217728query_cache_limit=16777216query_cache_min_res_unit=4096thread_cache_size=0key_buffer_size=8388608max_allowed_packet=1073741824sort_buffer_size=2097152read_rnd_buffer_size=262144bulk_insert_buffer_size=8388608myisam_sort_buffer_size=8388608innodb_buffer_pool_chunk_size=134217728innodb_buffer_pool_size=805306368max_heap_table_size=16777216tmp_table_size=16777216join_buffer_size=8388608max_connections=151table_open_cache=2048table_definition_cache=1408innodb_flush_log_at_trx_commit=1innodb_log_file_size=201326592innodb_log_buffer_size=16777216innodb_write_io_threads=4innodb_read_io_threads=4innodb_file_per_table=1innodb_flush_method=O_DIRECTinnodb_thread_concurrency=0innodb_purge_threads=4optimizer_search_depth=0thread_handling=pool-of-threadsthread_pool_size=2

测试结果

aimeos laravel 测试结果展示了默认配置和调整配置之间的显着性能改进。

mysql 的优化导致平均服务器响应时间显着改善,从 1.4 秒减少到 800 毫秒以下。

响应时间(延迟)下降了 42%,平均cpu 利用率下降了 86%,而每秒查询数增加了令人难以置信的 291%,从每秒 12 个查询增加到 35 个查询。

结果图表如下:

MySQL 调优如何提高 Laravel 性能响应时间(毫秒),aimeos 调整 mysql 配置与默认值
MySQL 调优如何提高 Laravel 性能cpu 利用率 (%),aimeos 调整 mysql 配置与默认值
MySQL 调优如何提高 Laravel 性能每秒查询数,aimeos 调整 mysql 配置与默认值

社区贡献者

我们与 initlab 公司的 laravel 开发者 gevorg mkrtchyan 和 sergey sinitsa 合作调查了这一问题,非常感谢他们的专业知识。

sergey 部署了 aimeos,gevorg 准备了用于播种数据库的代码。

结论

我们使用 aimeos laravel 的测试程序在配置数据库服务器配置后,在

响应时间(延迟)cpu 利用率每秒查询数方面显示出显着的改进。

响应时间(延迟)下降了 42%,而cpu 利用率下降了 86%。 aimeos laravel 500mb 中的每秒查询次数 增加了 291%。

总之,mysql 调优是数据库管理的一个重要方面,可以对 laravel 应用程序的性能产生重大影响。性能不佳的 web 应用程序可能会导致页面加载时间增加、请求处理缓慢以及用户体验不佳,从而对 seo 和销售产生负面影响。通过使用 mysql 调优优化 web 应用程序的性能,企业和组织可以提高销售额、浏览量、转化率和 seo 排名。

通过这项研究,我们希望展示 mysql 调优作为提高 laravel 应用程序性能的一种手段的价值,并鼓励 laravel 开发人员在优化应用程序性能时考虑这种做法。

使用 releem 等工具,可以自动配置数据库以获得最佳性能,减轻软件开发团队的负担。

以上就是MySQL 调优如何提高 Laravel 性能的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/62341.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月11日 06:08:59
下一篇 2025年11月11日 06:09:32

相关推荐

  • phph如何连接到数据库

    要使用 PHP 连接到数据库,请执行以下步骤:安装数据库扩展(如 MySQLi)。创建数据库连接(mysqli)。选择要使用的数据库(select_db)。执行查询(query)。处理查询结果(fetch_assoc、fetch_row、foreach)。关闭连接(close)。 如何使用 PHP …

    2025年12月12日
    000
  • 如何卸载phpmyadmin

    核心答案:卸载 phpMyAdmin 的步骤如下:停止 Web 服务器删除 phpMyAdmin 目录删除数据库用户删除 Web 服务器配置中的 phpMyAdmin 配置重新启动 Web 服务器 如何卸载 phpMyAdmin 步骤: 1. 停止 Apache 或 Nginx # 对于 Apach…

    2025年12月12日
    000
  • php如何和数据库连接

    PHP 连接数据库的方法:创建一个 MySQLi 对象。使用 mysqli_connect() 函数连接到数据库服务器。如果连接成功,使用 mysqli_select_db() 函数选择要使用的数据库。 PHP 连接数据库 如何连接数据库? 使用 PHP 连接数据库的步骤如下: 创建一个 mysql…

    2025年12月12日
    000
  • linux如何启动php

    在 Linux 上启动 PHP 的步骤包括:1. 安装 PHP;2. 启动 Apache 并启用 PHP 模块;3. 创建 PHP 文件;4. 访问 PHP 文件。 如何在 Linux 启动 PHP PHP 是一种广泛使用的服务器端脚本语言,用于创建动态网站和应用程序。在 Linux 系统上启动 P…

    2025年12月12日
    000
  • php如何获取mysql表中的最后一行

    如何从 MySQL 表中获取最后一行?直接获取方法:使用 LIMIT 1 逆序排序;使用 max() 函数:获取 ID 最大值,再查询具有该 ID 的行。 如何获取 MySQL 表中的最后一行 从 MySQL 表中获取最后一行可以采用以下方法之一: 直接获取方法 // 连接数据库$conn = ne…

    2025年12月12日
    000
  • 如何成为顶级php

    指南:成为顶级 PHP 开发者的步骤:掌握 PHP 基础知识。提升问题解决能力。学习设计模式。掌握数据库知识。了解网络编程。熟悉框架和库。实践和经验。持续学习和适应。 成为顶级 PHP 开发者的指南 1. 掌握语言基础 深入了解 PHP 语言语法、数据类型和面向对象编程。掌握 PHP 内置函数、扩展…

    2025年12月12日
    000
  • 如何用phpmyadmin导入数据库

    使用 phpMyAdmin 导入数据库的方法:连接到 phpMyAdmin 并选择数据库;单击“导入”选项卡并选择要导入的数据库文件;选择文件的格式并单击“执行”;处理导入过程中的任何错误(可选项);完成导入并验证数据导入是否成功。 如何在 phpMyAdmin 中导入数据库 phpMyAdmin …

    2025年12月12日
    000
  • winxp php如何运行

    要在 Windows XP 上运行 PHP,需要完成以下步骤:下载并安装 Apache Web Server下载并安装与 Apache 版本兼容的 PHP 版本,并选择安装“php_mysql”扩展名编辑 Apache 配置文件,添加 PHP 模块加载行在 Apache 文档根目录中创建 PHP 文…

    2025年12月12日
    000
  • 如何配置phpmyadmin

    如何配置 phpMyAdmin:安装软件包: 在 Linux 上通过 apt-get 安装,在 Windows 上下载安装程序。配置 Apache: 添加 phpMyAdmin 配置文件到 Apache 配置中。配置 phpMyAdmin: 设置强密码、用户名和密码。创建 MySQL 用户和数据库:…

    2025年12月12日
    000
  • 如何安装配置php

    如何在 Linux 上安装和配置 PHP?安装 PHP:通过命令行(Ubuntu/Debian:apt-get install php,CentOS/Red Hat:yum install php)或二进制文件安装。集成到 Web 服务器:对于 Apache(a2enmod php7.4/a2enm…

    2025年12月12日
    000
  • phpmyadmin 如何使用

    phpMyAdmin 是一种基于 Web 的数据库管理工具,用于管理 MySQL 数据库。安装:1. 确保服务器上有 MySQL;2. 下载并解压缩 phpMyAdmin 到服务器的 Web 目录;3. 配置 Web 服务器指向 phpMyAdmin 目录。访问:使用 MySQL 凭据登录 /php…

    2025年12月12日
    000
  • phpnow如何安装教程

    PHPNow是一个轻量级的PHP集成环境,提供一键式安装和配置。安装步骤如下:下载PHPNow安装程序。运行安装程序并按照提示操作。打开PHPNow程序。选择PHP版本。添加网站。启动网站。 PHPNow 安装教程 一、简介PHPNow是一个轻量级的PHP集成环境,它提供了一键式安装和配置,简化了在…

    2025年12月12日
    000
  • thinkphp 如何做直播

    使用 ThinkPHP 实现直播功能的方法有两种:与第三方直播云平台集成,提供即插即用的直播功能。开发自定义直播模块,高度定制化,不受平台限制。 ThinkPHP 直播开发指南 如何使用 ThinkPHP 实现直播功能? ThinkPHP 是一个优秀的 PHP 框架,可以通过集成第三方直播服务或开发…

    2025年12月12日
    000
  • 如何创建list.php文件

    创建一个 list.php 文件需要六个步骤:创建扩展名为 “.php” 的新文件添加 PHP 打开标签 将文件保存到文档根目录 如何创建 list.php 文件 步骤 1:创建新文件 使用文本编辑器或 IDE 创建一个新文件。将文件的扩展名设为 “.php&#8…

    2025年12月12日
    000
  • apache php如何运行

    在 Apache Web 服务器上运行 PHP 脚本需要以下步骤:安装 PHP;创建 Apache 配置文件并添加 PHP 加载模块;启用 PHP 模块;重启 Apache;创建 PHP 脚本并放在 Web 根目录中;访问 PHP 脚本以验证其运行。 如何运行 Apache PHP 在 Apache…

    2025年12月12日
    000
  • 源码php如何使用教程

    要使用 PHP 源代码,需要从官网下载并安装,安装路径因系统而异。PHP 源代码由 C 语言编写,包含函数、类和宏。开发者可通过源代码诊断问题、开发扩展并了解 PHP 的内部机制。注意,修改源代码时需谨慎,并遵守 BSD 许可证的版权声明。 如何使用 PHP 源码? 简介 PHP 源码是 PHP 编…

    2025年12月12日
    000
  • php如何写限时抢购

    如何在 PHP 中编写限时抢购?设置商品和时间限制:首先确定商品和限时抢购时间范围。创建数据库表:创建一个名为 flash_sales 的表来存储限时抢购信息。插入限时抢购数据:将限时抢购信息插入数据库。在购物车页面显示倒计时:计算剩余时间并显示倒计时。验证购买时的时间限制:检查购买时当前时间是否在…

    2025年12月12日
    000
  • php5.6如何连接mysql

    要在 PHP 5.6 中连接 MySQL 数据库,您需要:1. 建立连接;2. 检查连接是否成功;3. 执行查询;4. 处理查询结果;5. 关闭连接。 如何在 PHP 5.6 中连接 MySQL 概述: 要使用 PHP 5.6 连接 MySQL 数据库,可以使用以下步骤: 1. 建立连接: 立即学习…

    2025年12月12日
    000
  • 如何找php漏洞

    PHP 漏洞发现方法:开放源代码分析:检查代码库,寻找常见漏洞。工具使用:利用静态代码分析工具自动检测漏洞。输入验证:过滤和验证用户输入,防止代码注入。类型检查:确保变量类型匹配,防止转换漏洞。会话管理:避免会话固定和 CSRF。配置审核:审查 PHP 配置,启用安全功能。扩展审查:检查已安装扩展的…

    2025年12月12日
    000
  • mysql如何创建表php

    使用 PHP 创建 MySQL 表需要:建立到 MySQL 服务器的连接。定义表的结构,包括字段名称、类型和约束。使用 mysqli_query() 函数执行创建表查询。 如何使用 PHP 创建 MySQL 表 创建表 在 PHP 中,可以使用 mysqli_query() 函数创建 MySQL 表…

    2025年12月12日
    000

发表回复

登录后才能评论
关注微信