1STRACE-LOG-MERGE(1)         General Commands Manual        STRACE-LOG-MERGE(1)
2
3
4

NAME

6       strace-log-merge - merge strace -ff -tt output
7

SYNOPSIS

9       strace-log-merge STRACE_LOG
10
11       strace-log-merge --help
12

DESCRIPTION

14       strace-log-merge  merges  the  output  of  strace  -ff  -tt[t] command,
15       prepending PID to each line and sorting the result using time stamp  as
16       a key.
17

OPTIONS

19       --help Show program usage and exit.
20
21       STRACE_LOG
22              Output file name prefix of files produced by a strace -ff -tt[t]
23              command.
24

EXIT STATUS

26       0      Success
27
28       Non-zero
29              Error occurred: either no argument specified  (in  that  case  a
30              usage is printed), or something went wrong during the processing
31              of STRACE_LOG.*  files.
32

USAGE EXAMPLE

34       $ strace -o sleepy -ff -tt -e trace=execve,nanosleep \
35               sh -c 'sleep 0.1 & sleep 0.2 & sleep 0.3'
36       $ strace-log-merge sleepy | fold -w 72 -s
37       13475 21:13:52.040837 execve("/bin/sh", ["sh", "-c", "sleep 0.1 & sleep
38       0.2 & sleep 0."...], 0x7ffde54b2450 /* 33 vars */) = 0
39       13478 21:13:52.044050 execve("/bin/sleep", ["sleep", "0.3"],
40       0x5631be4f87a8 /* 33 vars */) = 0
41       13476 21:13:52.044269 execve("/bin/sleep", ["sleep", "0.1"],
42       0x5631be4f87a8 /* 33 vars */) = 0
43       13477 21:13:52.044389 execve("/bin/sleep", ["sleep", "0.2"],
44       0x5631be4f87a8 /* 33 vars */) = 0
45       13478 21:13:52.046207 nanosleep({tv_sec=0, tv_nsec=300000000}, NULL) = 0
46       13476 21:13:52.046303 nanosleep({tv_sec=0, tv_nsec=100000000}, NULL) = 0
47       13477 21:13:52.046318 nanosleep({tv_sec=0, tv_nsec=200000000}, NULL) = 0
48       13476 21:13:52.146852 +++ exited with 0 +++
49       13475 21:13:52.146942 --- SIGCHLD {si_signo=SIGCHLD,
50       si_code=CLD_EXITED, si_pid=13476, si_uid=1000, si_status=0, si_utime=0,
51       si_stime=0} ---
52       13477 21:13:52.247782 +++ exited with 0 +++
53       13475 21:13:52.247885 --- SIGCHLD {si_signo=SIGCHLD,
54       si_code=CLD_EXITED, si_pid=13477, si_uid=1000, si_status=0, si_utime=0,
55       si_stime=0} ---
56       13478 21:13:52.347680 +++ exited with 0 +++
57       13475 21:13:52.347786 --- SIGCHLD {si_signo=SIGCHLD,
58       si_code=CLD_EXITED, si_pid=13478, si_uid=1000, si_status=0, si_utime=0,
59       si_stime=0} ---
60       13475 21:13:52.348069 +++ exited with 0 +++
61
62

NOTES

64       strace-log-merge does not work  well  with  strace  logs  generated  by
65       strace -tt invocation that pass midnight, as those lack the information
66       required for the proper sorting.  Employing  the  -ttt  option  in  the
67       respective strace invocation should solve the problem.
68

BUGS

70       strace-log-merge  does  not perform any checks whether the files speci‐
71       fied are in the correct format and implies that only files from a  sin‐
72       gle strace session match STRACE_LOG.*  glob pattern.
73

HISTORY

75       The  initial  version of strace-log-merge was written by Denys Vlasenko
76       in 2012.
77

REPORTING BUGS

79       Problems with strace-log-merge should be reported to the strace mailing
80       list at <strace-devel@lists.strace.io>.
81

SEE ALSO

83       strace(1)
84
85
86
87strace 4.24                       2018-07-07               STRACE-LOG-MERGE(1)
Impressum