我正在做一个类似 CDN 的个人项目,我想对我的服务器进行压力测试,这是一个在 10Gbps VPS 上运行的最小 nginx+nodejs+ubuntu。我想模拟一些看起来更像服务器预期用途的东西:大约 10GB 的二进制数据由 nginx 后面的 nodejs 提供。与服务器的连接可以是 http 或 https,每个连接都是持久的,并以 1MB 的块突发请求数据,每个连接总共约 10-20MB。有些连接速度可能为 100mbps,延迟较低(占连接的 20%),有些连接速度可能慢至 100-200kbps,而 rtt ping 时间为 500ms(占连接的 5%)。我的目标是产生接近 10Gbps 理论限制的流量,并尝试监控服务器统计数据,收集分析数据以了解我的东西在负载下是如何工作的。连接到我的服务器的客户端也是我自己的代码。在所有客户端上,我想保存日志,然后组合和分析它们以估计当来自我的服务器的组合请求负载是理论限制的 50%、75%、... 90%、100%、120 时整个系统的一般结果% 等。在这些负载期间,我的目标是还观察服务器:ram 使用、cpu 负载、连接丢失率、验证日志记录(以确保组合的客户端记录与服务器记录的结果匹配)。
我的计划是首先在 1Gbps 服务器上进行测试(以及在不同地理位置的 10-15 x 100mbps 服务器来模拟客户端)。由于我控制客户端,我只是让它们运行某些场景并以不同的速度进行节流下载以模拟慢速客户端。
如果您需要对此类设置进行压力测试,您会怎么做?我的方法有什么问题吗?为什么?