AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1159499
Accepted
Gerrit
Gerrit
Asked: 2024-05-16 16:45:05 +0800 CST2024-05-16 16:45:05 +0800 CST 2024-05-16 16:45:05 +0800 CST

为什么我的 Azure Database for MySQL 一开始速度很慢

  • 772

我创建了一个 SaaS 产品。我使用 PHP 8.3 和 MySQL 8.0 数据库。在本地,这速度非常快!不使用框架等。生产在 Azure 上运行。我在 Azure 上进行了以下设置:

数据库

Azure Database for MySQL flexible server
- Burstable, B1s, 1 vCores, 1 GiB RAM, 20 GiB storage
- MySQL version 8

费用约为20欧元/月。

应用服务

Azure Web App
Basic B1, 100 ACU/vCPU, 1 vCPU, 1.75 memory (GB), 10 GB storage
OS: Linux

费用约为10欧元/月

我遇到的问题是,最初当随机用户访问我的网站并执行需要数据库查询的操作时。数据库一开始非常慢。可能是 3-10 秒!经过这个“热身”之后,访问该网站的每个新用户都没有任何延迟,并且数据库查询非常快。假设 30-60 分钟过去了,网站上没有任何活动,并且有新用户访问该网站,速度又变得非常慢。这不是我想要的。我需要做什么才能消除这种“热身”?

有人会说每月约 20 欧元的数据库性能会更好。我有更便宜、性能更好的 MySQL 数据库。

笔记:

  • Web 应用程序设置为“始终开启”
  • 我的数据库非常小并且经过完美优化,大约 5 个表,大约 100 条记录
  • 我的 'innodb_buffer_pool_dump_at_shutdown' 设置为ON
  • 我的“innodb_buffer_pool_load_at_startup”设置为ON
  • 我的“innodb_buffer_pool_size”是 134217728 字节(~128 mb)
  • MySql 和应用程序服务都在 vnet 中运行
  • MySql和App服务都使用ssl
  • 我所拥有的一切都在同一个地区(西欧),就像我的观众一样
mysql
  • 3 3 个回答
  • 77 Views

3 个回答

  • Voted
  1. Rick James
    2024-05-17T07:38:36+08:002024-05-17T07:38:36+08:00

    〜5 个表,〜100 条记录

    有多少数据?如果远大于 128MB,则需要增加 buffer_pool_size。

    但是...云实例中只有 1GB RAM,增加 buffer_pool 会导致交换,这对性能来说会很糟糕。

    每当数据库重新启动时,您是否可以访问您的网页?这可能会根据您的时间而不是用户的时间来填充缓存(buffer_pool)。

    您可能需要选择 2GB RAM 的实例。我会看看你为 Wilson 发布的内容;也许我可以提出不同的建议。

    同时,这里还有另一个调试工具: SlowLog

    • 1
  2. Wilson Hauck
    2024-05-23T02:12:28+08:002024-05-23T02:12:28+08:00

    格里特,

    在 my.ini [mysqld] 部分中,添加一行

    init_connect=SELECT 1;
    

    来参与实例。

    您可能需要

    USE (some_db);init_connect=SELECT 1;
    

    请告诉我们这是否可以消除您的“一开始慢”的情况。

    • 0
  3. Best Answer
    Gerrit
    2024-05-23T21:02:36+08:002024-05-23T21:02:36+08:00

    回复晚了,请原谅。最近几天我已经从“B1s 突发型”切换到“D2ds 通用型”进行测试。我认为我面临的问题是可突发数据库的一个特征。D2ds通用DB不存在这个问题。可突发的数据库不适用于我的业务环境,因此我正在切换到通用的保留数据库。

    • 0

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve