Merge branch '21941-keep-web-link' refs #21941
[arvados.git] / doc / user / cwl / crunchstat-summary.html.textile.liquid
1 ---
2 layout: default
3 navsection: userguide
4 title: Analyzing workflow performance
5 ...
6 {% comment %}
7 Copyright (C) The Arvados Authors. All rights reserved.
8
9 SPDX-License-Identifier: CC-BY-SA-3.0
10 {% endcomment %}
11
12 {% include 'tutorial_expectations' %}
13
14 *Note:* Starting from Arvados 2.7.2, these reports are generated automatically by @arvados-cwl-runner@ and can be found as @usage_report.html@ in a container request's log collection.
15
16 The @crunchstat-summary@ tool can be used to analyze workflow and container performance. It can be installed from packages (@apt install python3-crunchstat-summary@ or @dnf install python3-crunchstat-summary@), or in a Python virtualenv (@pip install crunchstat_summary@). @crunchstat-summary@ analyzes the crunchstat lines from the logs of a container or workflow and generates a report in text or html format.
17
18 h2(#syntax). Syntax
19
20 The @crunchstat-summary@ tool has a number of command line arguments:
21
22 <notextile>
23 <pre><code>~$ <span class="userinput">crunchstat-summary -h</span>
24 usage: crunchstat-summary [-h]
25                           [--job UUID | --container UUID | --pipeline-instance UUID | --log-file LOG_FILE]
26                           [--skip-child-jobs] [--format {html,text}]
27                           [--threads THREADS] [--verbose]
28
29 Summarize resource usage of an Arvados Crunch job
30
31 optional arguments:
32   -h, --help            show this help message and exit
33   --job UUID, --container-request UUID
34                         Look up the specified job or container request and
35                         read its log data from Keep (or from the Arvados event
36                         log, if the job is still running)
37   --container UUID      [Deprecated] Look up the specified container find its
38                         container request and read its log data from Keep (or
39                         from the Arvados event log, if the job is still
40                         running)
41   --pipeline-instance UUID
42                         [Deprecated] Summarize each component of the given
43                         pipeline instance (historical pre-1.4)
44   --log-file LOG_FILE   Read log data from a regular file
45   --skip-child-jobs     Do not include stats from child jobs/containers
46   --format {html,text}  Report format
47   --threads THREADS     Maximum worker threads to run
48   --verbose, -v         Log more information (once for progress, twice for
49                         debug)
50 </code></pre>
51 </notextile>
52
53 When @crunchstat-summary@ is given a container or container request uuid for a toplevel workflow runner container, it will generate a report for the whole workflow. If the workflow is big, it can take a long time to generate the report.
54
55 h2(#examples). Examples
56
57 @crunchstat-summary@ prints to stdout. The html report, in particular, should be redirected to a file and then loaded in a browser.
58
59 The html report can be generated as follows:
60
61 <notextile>
62 <pre><code>~$ <span class="userinput">crunchstat-summary --container-request pirca-xvhdp-rs0ef250emtmbj8 --format html > report.html</span>
63 </code></pre>
64 </notextile>
65
66 When loaded in a browser:
67
68 !(full-width)images/crunchstat-summary-html.png!
69
70 <br>
71
72 Using @--format text@ will print detailed usage and summary:
73
74 <notextile>
75 <pre><code>~$ <span class="userinput">crunchstat-summary --container-request pirca-xvhdp-rs0ef250emtmbj8 --format text</span>
76 category        metric  task_max        task_max_rate   job_total
77 blkio:0:0       read    63067755822     53687091.20     63067755822
78 blkio:0:0       write   64484253320     16376234.80     64484253320
79 cpu     cpus    16      -       -
80 cpu     sys     2147.29 0.60    2147.29
81 cpu     user    549046.22       15.99   549046.22
82 cpu     user+sys        551193.51       16.00   551193.51
83 fuseop:create   count   1       0.10    1
84 fuseop:create   time    0.01    0.00    0.01
85 fuseop:destroy  count   0       0       0
86 fuseop:destroy  time    0       0       0.00
87 fuseop:flush    count   12      0.70    12
88 fuseop:flush    time    0.00    0.00    0.00
89 fuseop:forget   count   0       0       0
90 fuseop:forget   time    0       0       0.00
91 fuseop:getattr  count   40      2.70    40
92 fuseop:getattr  time    0.00    0.00    0.00
93 fuseop:lookup   count   36      2.90    36
94 fuseop:lookup   time    0.67    0.07    0.67
95 fuseop:mkdir    count   0       0       0
96 fuseop:mkdir    time    0       0       0.00
97 fuseop:on_event count   0       0       0
98 fuseop:on_event time    0       0       0.00
99 fuseop:open     count   9       0.30    9
100 fuseop:open     time    0.00    0.00    0.00
101 fuseop:opendir  count   0       0       0
102 fuseop:opendir  time    0       0       0.00
103 fuseop:read     count   481185  409.60  481185
104 fuseop:read     time    370.11  2.14    370.11
105 fuseop:readdir  count   0       0       0
106 fuseop:readdir  time    0       0       0.00
107 fuseop:release  count   7       0.30    7
108 fuseop:release  time    0.00    0.00    0.00
109 fuseop:rename   count   0       0       0
110 fuseop:rename   time    0       0       0.00
111 fuseop:rmdir    count   0       0       0
112 fuseop:rmdir    time    0       0       0.00
113 fuseop:setattr  count   0       0       0
114 fuseop:setattr  time    0       0       0.00
115 fuseop:statfs   count   0       0       0
116 fuseop:statfs   time    0       0       0.00
117 fuseop:unlink   count   0       0       0
118 fuseop:unlink   time    0       0       0.00
119 fuseop:write    count   5414406 1123.00 5414406
120 fuseop:write    time    475.04  0.11    475.04
121 fuseops read    481185  409.60  481185
122 fuseops write   5414406 1123.00 5414406
123 keepcache       hit     961402  819.20  961402
124 keepcache       miss    946     0.90    946
125 keepcalls       get     962348  820.00  962348
126 keepcalls       put     961     0.30    961
127 mem     cache   22748987392     -       -
128 mem     pgmajfault      0       -       0
129 mem     rss     27185491968     -       -
130 net:docker0     rx      0       -       0
131 net:docker0     tx      0       -       0
132 net:docker0     tx+rx   0       -       0
133 net:ens5        rx      1100398604      -       1100398604
134 net:ens5        tx      1445464 -       1445464
135 net:ens5        tx+rx   1101844068      -       1101844068
136 net:keep0       rx      63086467386     53687091.20     63086467386
137 net:keep0       tx      64482237590     20131128.60     64482237590
138 net:keep0       tx+rx   127568704976    53687091.20     127568704976
139 statfs  available       398721179648    -       398721179648
140 statfs  total   400289181696    -       400289181696
141 statfs  used    1568198656      0       1568002048
142 time    elapsed 34820   -       34820
143 # Elapsed time: 9h 40m 20s
144 # Assigned instance type: m5.4xlarge
145 # Instance hourly price: $0.768
146 # Max CPU usage in a single interval: 1599.52%
147 # Overall CPU usage: 1582.98%
148 # Requested CPU cores: 16
149 # Instance VCPUs: 16
150 # Max memory used: 25926.11MB
151 # Requested RAM: 50000.00MB
152 # Maximum RAM request for this instance type: 61736.70MB
153 # Max network traffic: 127.57GB
154 # Max network speed in a single interval: 53.69MB/s
155 # Keep cache miss rate: 0.10%
156 # Keep cache utilization: 99.97%
157 # Temp disk utilization: 0.39%
158 </code></pre>
159 </notextile>