16

我正在尝试以分布式模式设置 JMeter。我有一个在 ec2 实例上运行的服务器,我希望主服务器在我的本地计算机上运行。我不得不跳过一些希望让 RMI 在服务器上正常工作,但通过将“java.rmi.server.hostname”设置为 ec2 实例的 IP 来解决。

下一个(希望是最后一个)问题是服务器与主服务器通信。

问题是因为我是从内部网络执行此操作的,所以当它应该发送回我的外部连接的 IP (92.XXX.XXX. XXX)。

我可以在 jmeter-server.log 中看到这一点:

错误 - jmeter.samplers.RemoteListenerWrapper: testStarted(host) java.rmi.ConnectException: Connection denied to host: 192.168.1.50; 嵌套异常是:

那个主机IP是错误的。它应该是 92.XXX.XXX.XX 地址。我认为这是因为在主日志中我看到以下内容:

2012/07/29 20:45:25 信息 - jmeter.JMeter:IP:192.168.1.50 名称:XXXXXX.local 全名:192.168.1.50

这个 IP 在 RMI 设置期间被发送到服务器。

所以我想我有两个选择:

  1. 告诉master发送外部IP
  2. 告诉服务器连接到主服务器的外部 IP。

但我看不到在哪里设置这些命令。

任何帮助都会很有用。

4

4 回答 4

27

为了未来读者的利益,不要拒绝回答。有可能的!另外,您可以将防火墙保持在适当的位置。

在这种情况下,我在端口 4000 上做了所有事情。

如何连接 JMeter 客户端和服务器以使用 Amazon EC2 实例和跨不同网络的本地开发机器进行分布式测试。

设置:

  1. JMeter 2.13 客户端:本地开发计算机(不同网络)
  2. JMeter 2.13 服务器:Amazon EC2 实例

我配置分布式客户端/服务器 JMeter 连接如下:

1.在我的防火墙/路由器上添加了端口转发规则:

  • 端口:4000
  • 目的地:局域网上的 JMeter 客户端私有 IP 地址。

2. 在 EC2 实例上配置“安全组”设置:

  • 类型:允许:入站
  • 端口:4000
  • 来源:JMeter客户端公网IP地址(我的开发电脑/网络公网IP)

更新:如果您已经有 SSH 连接,您可以使用 SSH 隧道进行连接,这将避免需要添加防火墙规则。

$ ssh -i ~/.ssh/54-179-XXX-XXX.pem ServerAliveInterval=60 -R 4000:localhost:4000 jmeter@54.179.XXX.XXX

3.配置客户端$JMETER_HOME/bin/jmeter.properties文件RMI部分:

请注意,此处仅包含我更改的非默认值:

#---------------------------------------------------------------------------
# Remote hosts and RMI configuration
#---------------------------------------------------------------------------

# Remote Hosts - comma delimited
# Add EC2 JMeter server public IP address:Port combo
remote_hosts=127.0.0.1,54.179.XXX.XXX:4000

# RMI port to be used by the server (must start rmiregistry with same port)
server_port=4000

# Parameter that controls the RMI port used by the RemoteSampleListenerImpl (The Controler)
# Default value is 0 which means port is randomly assigned
# You may need to open Firewall port on the Controller machine
client.rmi.localport=4000

# To change the default port (1099) used to access the server:
server.rmi.port=4000

# To use a specific port for the JMeter server engine, define
# the following property before starting the server:
server.rmi.localport=4000

4.配置远程服务器$JMETER_HOME/bin/jmeter.properties文件RMI部分如下:

#---------------------------------------------------------------------------
# Remote hosts and RMI configuration
#---------------------------------------------------------------------------

# RMI port to be used by the server (must start rmiregistry with same port)
server_port=4000

# Parameter that controls the RMI port used by the RemoteSampleListenerImpl (The Controler)
# Default value is 0 which means port is randomly assigned
# You may need to open Firewall port on the Controller machine
client.rmi.localport=4000

# To use a specific port for the JMeter server engine, define
# the following property before starting the server:
server.rmi.localport=4000

5. 使用以下命令启动 JMeter 服务器/从站:

jmeter-server -Djava.rmi.server.hostname=54.179.XXX.XXX

其中 54.179.XXX.XXX 是 EC2 服务器的公共 IP 地址

6. 使用以下命令启动 JMeter 客户端/主机:

jmeter -Djava.rmi.server.hostname=121.73.XXX.XXX

其中 121.73.XXX.XXX 是我的客户端计算机的公共 IP 地址。

7. 运行一个 JMeter 测试套件。

在此处输入图像描述 JMeter GUI 日志输出

成功!

于 2015-06-24T08:43:32.093 回答
7

我有一个类似的问题:JMeter 服务器试图连接到错误的地址来发送测试结果(它试图连接到 localhost)。

我通过在启动 JMeter master 时设置以下参数解决了这个问题:

-Djava.rmi.server.hostname=xx.xx.xx.xx

于 2013-09-05T08:24:39.327 回答
5

看起来好像这不起作用分布式 JMeter 测试解释了在分布式环境中进行负载测试的要求。我相信第 2 和第 3 是您的用例所特有的。

  1. 系统上的防火墙已关闭。
  2. 所有客户端都在同一个子网上。
  3. 如果使用 192.xxx 或 10.xxx ip 地址,则服务器在同一子网中。
  4. 确保 JMeter 可以访问服务器。
  5. 确保在所有系统上使用相同版本的 JMeter。混合版本可能无法正常工作。
于 2012-07-30T20:36:33.320 回答
0

可能在比赛中很晚,但仍然。我用 jmeter 5.3 运行它。

因此,通过在 aws 中设置从站和本地计算机上的控制器来使其工作。

  1. 确保您的从站具有正确的本地端口和主机名。从站上的主机名应该是 ec2 实例公共 dns。
  2. 确保 AWS 具有适当的安全策略。
  3. 对于控制器(这是您的本地机器),请确保您使用参数“-Djava.rmi.server.hostname=”运行。你可以通过谷歌搜索“我的公共IP地址”来获取IP。绝对不是那些 192.xxx.xxx.x 或 172.xx.xxx。
  4. 然后,您必须配置调制解调器以端口转发您的机器,该机器曾经是您的控制器。可以从从属日志中获取端口(具有 FINE: RMI RenewClean .....,是的,您必须将日志设置为详细)。或设置 DMZ 并放置您的控制器机器。危险,但只是为了测试时间方便,之后不要忘记关闭它
  5. 然后它应该工作。
于 2021-04-02T04:30:09.467 回答