summaryrefslogtreecommitdiffstats
path: root/doc/dev/messenger.rst
blob: 7295389136ef5707b3968b451f9c9638e5bd8e91 (plain)
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
============================
 Messenger notes
============================

Messenger is the Ceph network layer implementation. Currently Ceph supports
one messenger type: "async".

ceph_perf_msgr
==============

ceph_perf_msgr is used to do benchmark for messenger module only and can help
to find the bottleneck or time consuming within messenger moduleIt just like
"iperf", we need to start server-side program firstly:

# ./ceph_perf_msgr_server 172.16.30.181:10001 1 0

The first argument is ip:port pair which is telling the destination address the
client need to specified. The second argument configures the server threads. The
third argument tells the "think time"(us) when dispatching messages. After Giant,
CEPH_OSD_OP message which is the actual client read/write io request is fast
dispatched without queueing to Dispatcher, in order to achieve better performance.
So CEPH_OSD_OP message will be processed inline, "think time" is used by mock
this "inline process" process.

# ./ceph_perf_msgr_client 172.16.30.181:10001 1 32 10000 10 4096 

The first argument is specified the server ip:port, and the second argument is
used to specify client threads. The third argument specify the concurrency(the
max inflight messages for each client thread), the fourth argument specify the
io numbers will be issued to server per client thread. The fifth argument is
used to indicate the "think time" for client thread when receiving messages,
this is also used to mock the client fast dispatch process. The last argument
specify the message data length to issue.