我创建了一个 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
- 我所拥有的一切都在同一个地区(西欧),就像我的观众一样
有多少数据?如果远大于 128MB,则需要增加 buffer_pool_size。
但是...云实例中只有 1GB RAM,增加 buffer_pool 会导致交换,这对性能来说会很糟糕。
每当数据库重新启动时,您是否可以访问您的网页?这可能会根据您的时间而不是用户的时间来填充缓存(buffer_pool)。
您可能需要选择 2GB RAM 的实例。我会看看你为 Wilson 发布的内容;也许我可以提出不同的建议。
同时,这里还有另一个调试工具: SlowLog
格里特,
在 my.ini [mysqld] 部分中,添加一行
来参与实例。
您可能需要
请告诉我们这是否可以消除您的“一开始慢”的情况。
回复晚了,请原谅。最近几天我已经从“B1s 突发型”切换到“D2ds 通用型”进行测试。我认为我面临的问题是可突发数据库的一个特征。D2ds通用DB不存在这个问题。可突发的数据库不适用于我的业务环境,因此我正在切换到通用的保留数据库。