MongooseIM的Tsung负载测试(websockets)

时间:2013-12-09 21:20:07

标签: websocket load-testing tsung mongoose-im

我的问题是将我的tsung.xml文件配置为加载测试聊天应用程序。

因此,我们在服务器端安装了MongooseIM服务器,为基于Web的客户端安装了jsjac.js库。我们使用xmpp和websockets进行通信。

jsjac的httpbase看起来像ws://hostname:5288/ws-xmpp/,这部分对我来说很好。 Tsung支持“从框中”的websockets,每个人都说测试websockets的最佳方法是使用tsung。但关于如何做到这一点的信息并不多。

这是我的tsung.xml:

<?xml version="1.0"?>
<!DOCTYPE tsung SYSTEM "/usr/share/tsung/tsung-1.0.dtd">
<tsung loglevel="notice" version="1.0">
  <clients>
    <client host="localhost" use_controller_vm="true" maxusers="10" />
  </clients>

  <servers>
    <server host="hostname" port="5288" type="tcp" />
  </servers>

  <load>
    <arrivalphase phase="1" duration="10" unit="second">
      <users maxnumber="1" arrivalrate="1" unit="second" />
    </arrivalphase>
  </load>

  <sessions>
    <session name="websocket" probability="100" type="ts_websocket">
        <request subst="true">
             <websocket type="connect" path="/ws-xmpp"></websocket>
        </request>

        <request>
            <dyn_variable name="uid" jsonpath="uid"/>
            <websocket type="message">{"user":"bob", "password":"bob"}</websocket>
        </request>  

        <request subst="true">
            <match do="log" when="nomatch">ok</match>
            <websocket type="message">{"uid":"%%_uid%%", "data":"data"}</websocket>
        </request>

        <request>
        <websocket type ="message">{"key":"value"}</websocket>      
        </request>

        <request>
            <websocket type="close"></websocket>
        </request>
    </session>
  </sessions>
</tsung>

并且在测试通过后结果是:

connected: 0
finish_users_count: 1
users: 1
users count: 1
websocket_succ: 1

用户“bob”确实存在于服务器的数据库中,并且可以通过客户端应用程序正常工作。

有谁能告诉我我做错了什么? 或者有人可以提供某些文章或工作xml文件的链接?
感谢。

2 个答案:

答案 0 :(得分:1)

通过Websockets测试XMPP的最佳方法是使用具有特定服务器配置的标准Jabber方案:

<servers>
  <server host="localhost" port="5288" type="websocket"></server>
</servers>

<options>
  (...)
  <option name="websocket_path" value="/ws-xmpp"/>
</options>

可以找到示例Jabber场景,例如在Tsung repo的“examples”目录中。我认为明文登录是在那里使用的,所以如果你仍然有连接用户的问题,用以下代码替换事务“authenticate”:

<transaction name="authenticate">
  <request><jabber type="auth_sasl" ack="local" /></request>
  <request><jabber type="connect" ack="local" /></request>
  <request><jabber type="auth_sasl_bind" ack="local" /></request>
  <request><jabber type="auth_sasl_session" ack="local" /></request>
</transaction>

答案 1 :(得分:0)

有几件事要做......所以,首先,非常感谢Piotr! 他的回答(+ jabber场景示例)帮助解决了我的问题

这是我的工作tsung.xml

<?xml version="1.0"?>
<!DOCTYPE tsung SYSTEM "/usr/share/tsung/tsung-1.0.dtd">
<tsung loglevel="notice" version="1.0">
  <clients>
    <client host="localhost" use_controller_vm="true"></client>
  </clients>
  <!-- Server side setup -->
 <servers>
  <server host="servernameOrIp" port="5288" type="websocket"></server>
 </servers>
  <load>
   <arrivalphase phase="1" duration="20" unit="second">
    <users interarrival="1" unit="second"></users>
   </arrivalphase>
  </load>
  <!-- JABBER parameters -->
 <options>
  <option type="ts_jabber" name="global_number" value="20"></option>
  <option type="ts_jabber" name="userid_max" value="20"></option>
  <option type="ts_jabber" name="domain" value="servernameOrIp"></option>
  <option type="ts_jabber" name="username" value="user00"></option>
  <option type="ts_jabber" name="passwd" value="user00"></option>
  <option name="websocket_path" value="/ws-xmpp"/>
 </options>

  <sessions>
   <session probability="100" name="jabber-example" type="ts_jabber">
    <request> <jabber type="connect" ack="no_ack"></jabber> </request>
    <thinktime value="2"></thinktime>
    <transaction name="authenticate">
    <request><jabber type="auth_sasl" ack="local" /></request>
    <request><jabber type="connect" ack="local" /></request>
    <request><jabber type="auth_sasl_bind" ack="local" /></request>
    <request><jabber type="auth_sasl_session" ack="local" /></request>
    </transaction>
    <request> <jabber type="presence:initial" ack="no_ack"/> </request>
    <thinktime value="10"></thinktime>
    <transaction name="roster">
      <request> <jabber type="iq:roster:get" ack="local"></jabber></request>
    </transaction>
    <thinktime value="10"></thinktime>
    <transaction name="online">
    <request> <jabber type="chat" ack="no_ack" size="16" destination="online"></jabber> </request>
    </transaction>
    <thinktime value="10"></thinktime>
    <transaction name="offline">
      <request> <jabber type="chat" ack="no_ack" size="56" destination="offline"></jabber> </request>
    </transaction>
    <thinktime value="2"></thinktime>
    <transaction name="close">
      <request> <jabber type="close" ack="no_ack"></jabber> </request>
    </transaction>
  </session>
 </sessions>
</tsung>

使用此tsung生成20个用户(user001 - user0020),我可以在我的“bob's”名单中看到它们。我使用Spark IM客户端来监控它。