File: features.rst

package info (click to toggle)
tsung 1.8.0-0.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,932 kB
  • sloc: erlang: 25,486; javascript: 10,347; sh: 3,109; perl: 1,025; makefile: 624; python: 372
file content (235 lines) | stat: -rw-r--r-- 6,703 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
.. _ab: http://httpd.apache.org/docs/current/programs/ab.html

========
Features
========


Tsung main features
===================

* *High Performance*: ``Tsung`` can simulate a huge number of
  simultaneous users per physical computer: It can simulates thousands
  of users on a single CPU (Note: a simulated user is not always
  active: it can be idle during a ``thinktime``
  period). Traditional injection tools can hardly go further than a 
  few hundreds (Hint: if all you want to do is requesting a single URL
  in a loop, use ab_; but if you want to build complex
  scenarios with extended reports, ``Tsung`` is for you).

* *Distributed*: the load can be distributed on a cluster of client machines

* *Multi-Protocols* using a plug-in system: HTTP (both standard web
  traffic and SOAP), WebDAV, Jabber/XMPP and PostgreSQL are currently
  supported. LDAP and MySQL plugins were first included in the 1.3.0 release.

* *SSL* support

* *Several IP addresses* can be used on a single machine using the underlying OS IP Aliasing

* *OS monitoring* (CPU, memory and network traffic) using Erlang agents on remote servers or *SNMP*

* *XML configuration system*: complex user's scenarios are
  written in XML. Scenarios can be written with a simple browser using the
  Tsung recorder (HTTP and PostgreSQL only).

* *Dynamic scenarios*: You can get dynamic data from the
  server under load (without writing any code) and re-inject it in
  subsequent requests. You can also loop, restart or stop a
  session when a string (or regexp) matches the server response.

* *Mixed behaviours*: several :ref:`sessions <sessions-label>` can be used to simulate
  different type of users during the same benchmark. You can define
  the proportion of the various behaviours in the benchmark scenario.

* *Stochastic processes*: in order to generate a realistic
  traffic, user thinktimes and the arrival rate can be randomized
  using a probability distribution (currently exponential)


HTTP related features
=====================


* HTTP/1.0 and HTTP/1.1 support

* GET, POST, PUT, DELETE, HEAD, OPTIONS, PURGE and PATCH requests

* Cookies: Automatic cookies management (but you can also manually add
  more cookies)

* 'GET If-modified since' type of request

* WWW-authentication Basic and Digest. OAuth 1.0

* User Agent support

* Any HTTP Headers can be added

* Proxy mode to record sessions using a Web browser

* SOAP support using the HTTP mode (the SOAPAction HTTP header is
  handled).

* HTTP server or proxy server load testing.


WEBDAV related features
=======================

The WebDAV (:RFC:`4918`) plugin is a superset of the HTTP plugin. It adds the
following features (some versioning extensions to WebDAV (:RFC:`3253`)
are also supported):


* Methods implemented: DELETE, CONNECT, PROPFIND, PROPPATCH, COPY,
  MOVE, LOCK, UNLOCK, MKCOL, REPORT, OPTIONS, MKACTIVITY, CHECKOUT, MERGE

* Recording of DEPTH, IF, TIMEOUT OVERWRITE, DESTINATION, URL and
  LOCK-TOKEN Headers.


Jabber/XMPP related features
============================

* Authentication (plain-text, digest and sip-digest). STARTTLS

* presence and register messages

* Chat messages to online or offline users

* MUC: join room, send message in room, change nickname

* Roster set and get requests

* Global users' synchronization can be set on specific actions

* BOSH & XMPP over Websocket

* raw XML messages

* PubSub

* Multiple vhost instances supported

* privacy lists: get all privacy list names, set list as active


PostgreSQL related features
===========================

* Basic and MD5 Authentication
* Simple Protocol
* Extended Protocol (new in version **1.4.0** )
* Proxy mode to record sessions


MySQL related features
======================
This plugin is experimental. It works only with MySQL version 4.1 and higher.

* Secured Authentication method only (MySQL >= 4.1)

* Basic Queries


Websocket related features
==========================

This plugin is experimental. It only supports :RFC:`6455` currently.
For used as a server type, it works like other transport protocol like
tcp and udp, any application specific protocol data can be send on it.

You can find examples used as session type in examples/websocket.xml.

* Both as a server type and session type


AMQP related features
=====================

This plugin is experimental. It only supports AMQP-0.9.1 currently.
You can find examples in examples/amqp.xml.

* Basic publish and consume

* Publisher confirm and consumer ack

* QoS

MQTT related features
=====================

This plugin is experimental. It supports MQTT V3.1.
You can find examples in examples/mqtt.xml.

* Connect to mqtt broker with options

* Publish mqtt messages to the broker

* Subscribe/unsubscribe topics

* Support QoS 0 and QoS 1

LDAP related features
=====================

* Bind

* Add, modify and search queries

* Starttls

Raw plugin related features
===========================

* TCP / UDP / SSL compatible

* raw messages

* no_ack, local or global ack for messages


Complete reports set
====================

Measures and statistics produced by Tsung are extremely feature-full.
They are all represented as a graphic. ``Tsung`` produces
statistics regarding:


* *Performance*: response time, connection time,  decomposition of the
  user scenario based on request grouping  instruction (called
  *transactions*), requests per second

* *Errors*: Statistics on page return code to trace errors

* *Target server behaviour*: An Erlang agent can gather information
  from the target server(s). Tsung produces graphs for CPU and memory
  consumption and network traffic. SNMP and munin is also supported to
  monitor remote servers.

\par Note that ``Tsung`` takes care of the synchronization process by itself. Gathered statistics are «synchronized».

It is possible to generate graphs during the benchmark as statistics are gathered in real-time.

Highlights
==========

``Tsung`` has several advantages over other injection tools:


* *High performance* and *distributed benchmark*: You can use Tsung to simulate tens of thousands of virtual users.

* *Ease of use*: The hard work is already done for all supported
  protocol. No need to write complex scripts. Dynamic scenarios only requires small trivial piece of code.

* *Multi-protocol support*: ``Tsung`` is for example one of the only tool to benchmark SOAP applications

* *Monitoring* of the target server(s) to analyze the behaviour and
  find bottlenecks. For example, it has been used to analyze cluster
  symmetry (is the load properly balanced ?) and to determine the best
  combination of machines on the three cluster tiers (Web engine, EJB
  engine and database)