我创建了一个 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
- 我所拥有的一切都在同一个地区(西欧),就像我的观众一样