- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的任务是对我的团队设计和构建的软件进行负载测试。它是一个 Java Web 应用程序,充当我公司制作的所有其他应用程序的 API。
这是系统的粗略轮廓:
1) Application 1 needs information from the database.
2) App 1 produces a request to a rabbit exchange (routing key for the queue that is consumed by the tool I'm testing).
3) My tool consumes the RabbitMQ queue that App1 pushed to
4) My tool executes the request sent from App1 via the Rabbit queue
5) My tool then sends the response back to App 1 via a Rabbit Exchange/Reply Queue.
6) App 1 then consumes from the reply queue and handles the response
这是一个非常低级别的 View ,因为每个应用程序都有很多实例发布到队列并使用队列。
我以前从未对任何东西进行过负载测试,所以我对可用的概念和工具很陌生。
现在我正在使用 jMeter 发起调用并使用回复(我让它像示例中的应用程序 1 一样运行,它通过兔子调用并使用回复)。
这是我的问题:
1) Is this a viable way to load test? Should I be testing the capacity of the server directly or should I continue going through rabbit since it's a closer to production use case?
2) What is the best way to adjust my rate of production? I've tried doing some throttling via jMeter but when I look at the rabbit graphs the publish rate seems to fluctuate wildly. Example: I tell jMeter to publish at 1000 messages/sec and the graph on the rabbit dashboard goes from 500/sec to 3000/sec. I don't feel like I can accurately get an idea of what we can handle if I can reliably adjust the rate.
我的计划是:
1) Find the rate at which my application can't pick things off the queue fast enough. (where the rate of publishing to the queue becomes faster than my application can consume them).
2) Once I know the fastest I can send stuff to the queue I can check the responses for error rate and processing time.
我在想,通过这样做,我可以计算出我们可以发布到队列的最大速率,同时仍处于可接受的错误率范围内,并了解周转时间是多少。
还有什么我应该寻找的吗?为了取得成功,我应该了解负载测试的任何“规则”?
谢谢!
最佳答案
我认为你应该考虑以下事情,
对于任何复杂系统(包括多个组件)的负载测试,请按组件(App1、Rabbit 队列、生产者、消费者)划分负载测试。
这背后的原因是在一次测试中你无法获得系统中的瓶颈,否则会导致不正确的结果。
在我的团队中,我们曾经有过这样的任务(发布者 - 消费者模型)。没有任何规则规定进行负载测试时您必须使用任何负载测试工具。可以充当负载生成器(发布者)的简单 java 代码和消耗负载(消费者)的简单 java 代码足以进行负载测试。
JMeter 是一个不错的选择(免费、可扩展、可靠、业界知名),但您可以检查 LoadRunner、Neoload 等。
恕我直言,您应该分离组件并单独测试它们,这将帮助您找到答案,例如什么是最大消费者速率和什么是最大发布者速率。一个简单的 java 代码就可以为您做到这一点。您不需要 JMeter 请求。这样您就可以更好地控制生产率和消耗率。
是的,你的计划是正确的,找到最大值。定价发布者和消费者可以为您提供的最大可能价格。系统吞吐量。执行此操作时,还要注意系统利用率。
最后,当您获得稳定系统的测量值时,您可以选择 2 个选项,
1. Stress test (when system breaks)
2. Tune the system to improve the performance and repeat the cycle for new measurements.
我希望现在一些困惑已经清楚了:)
关于java - 寻求设计负载测试的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27284001/
在 Web 应用程序架构设计期间,我必须从概念上计算我的服务器之一可以服务多少个当前客户端。然后我可以预算它。 那么,有什么公式可以遵循吗?或者,你如何计算这个?或者,通常,一个 httpd/tomc
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找书籍、工具、软件库、教程或其他场外资源的问题对于 Stack Overflow 来说是
我正在使用 Angular 5,我正在尝试在加载 div 的背景图像时获取加载图标。 如果它是一个普通的 img,我对此没有问题,但如果我尝试将它作为背景,它就不起作用。 这里是一些示例代码 app.
我们怎么知道我们的程序在 CPU 上有多少负载? 我尝试使用 htop 找到它。但是 htop 不会给 cpu 负载。它实际上给出了我程序的 cpu 利用率(使用 pid)。 我正在使用 C 编程,L
我们发现从Spark 1.3到当前的Spark 2.0.1以来,从Oracle数据库使用Spark的API加载数据一直很慢。典型的代码在Java中是这样的: Map options =
我有时会收到 mnesia overloaded主要使用时的错误消息 async_dirty查询和 ram_copies表。所以为了了解发生了什么,我想获得更多关于 mnesia 状态的信息,例如每秒
对于通常使用很少 CPU 的程序来说,内核 CPU 非常高。 Linux 机器在状态之间交替。大多数时候,程序使用低 CPU 正常执行。在 CPU“激增”期间,程序使用 100% 可用 CPU 使用高
我正在使用 Raspberry Pi 2 来路由 wifi-eth 连接。因此,从 eth 方面来看,我有一台可以使用 Pi wifi 连接到互联网的计算机。在 Raspberry 上我启动 htop
基本上我有一个网页,其中有一个 iframe 可以从不同的域加载另一个网页。它移动得很慢,我想证明整个页面很慢只是因为 iframe 内的页面。 有什么方法可以测量总页面负载以及总页面负载中有多少%来
我们有一个基于 Spring 的应用程序,它充当使用其他 Rest API 的编排层。我只想测试这个组件的性能,而不测试正在使用的下游 api。 我正在寻找有关如何完成此操作的任何架构建议? 当前的方
我正在学习 hibernate 。为了进行测试,我使用无效 key 调用了 session.load 。当我在调试器(JB Idea)中跨过该行后,没有任何反应 - 我预计会得到 ObjectNotF
我正在开发一个小型的待办事项 PHP 应用程序。我正在使用 jQuery 构建 HTML。其中一个是一个按钮,用于启动一个模式,允许用户编辑该项目。我很好奇加载数据时更好的方法是什么: 1) 在初始加
我尝试在 twitch 播放器中使用 angular 作为覆盖标记。 我将 ng-repear 与(键,值)结合使用。 //player is here 设置是一个全局对象。但是当我尝试加载页面
我即将了解 C 语言中的特定进程如何在特定时间范围内加载 CPU。该进程可能会在运行时切换处理器核心,因此我也需要处理这个问题。 CPU为ARM处理器。 我研究了从标准顶部获取负载的不同方法,perf
这个问题在这里已经有了答案: XMLHttpRequest Origin null is not allowed Access-Control-Allow-Origin for file:/// t
您好,我正在用 Java 开发负载平衡算法。在我的系统中将有一个主节点和 n 个从节点。主节点将接收查询分发给它的从节点。但是在将查询分发到其从节点之一之前,我想测量从节点中的当前负载,以检查特定从节
我正在渲染由大约 50 万个三角形组成的相当重的对象。我使用 opengl 显示列表,在渲染方法中只调用 glCallList。我认为一旦图形基元被编译成显示列表,cpu 的工作就完成了,它只是告诉
我正在尝试加密 Sipdroid,为此我必须在 RTP 数据包获得编码的音频负载后对其进行加密。我在 RTP 数据包类中使用这个函数: public byte[] getPayload() {
我正在尝试解析以下 JSON 负载: { "results":[ [ 298.648132, 280.68692, 356.54
在动画期间 cpu 负载非常高(高达 75%) 是否有优化代码以降低 CPU 负载的方法? 我的代码: ImageView myImageView = (ImageView)findViewById(
我是一名优秀的程序员,十分优秀!