Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
bcc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
bcc
Commits
702de38d
Commit
702de38d
authored
Jan 28, 2018
by
Paul Chaignon
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
opensnoop: -d option for duration
parent
44463d53
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
33 additions
and
4 deletions
+33
-4
man/man8/opensnoop.8
man/man8/opensnoop.8
+8
-1
tools/opensnoop.py
tools/opensnoop.py
+9
-2
tools/opensnoop_example.txt
tools/opensnoop_example.txt
+16
-1
No files found.
man/man8/opensnoop.8
View file @
702de38d
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
.SH NAME
.SH NAME
opensnoop \- Trace open() syscalls. Uses Linux eBPF/bcc.
opensnoop \- Trace open() syscalls. Uses Linux eBPF/bcc.
.SH SYNOPSIS
.SH SYNOPSIS
.B opensnoop [\-h] [\-T] [\-x] [\-p PID] [\-t TID] [\-n name]
.B opensnoop [\-h] [\-T] [\-x] [\-p PID] [\-t TID] [\-
d DURATION] [\-
n name]
.SH DESCRIPTION
.SH DESCRIPTION
opensnoop traces the open() syscall, showing which processes are attempting
opensnoop traces the open() syscall, showing which processes are attempting
to open which files. This can be useful for determining the location of config
to open which files. This can be useful for determining the location of config
...
@@ -36,6 +36,9 @@ Trace this process ID only (filtered in-kernel).
...
@@ -36,6 +36,9 @@ Trace this process ID only (filtered in-kernel).
\-t TID
\-t TID
Trace this thread ID only (filtered in-kernel).
Trace this thread ID only (filtered in-kernel).
.TP
.TP
\-d DURATION
Total duration of trace in seconds.
.TP
\-n name
\-n name
Only print processes where its name partially matches 'name'
Only print processes where its name partially matches 'name'
.SH EXAMPLES
.SH EXAMPLES
...
@@ -44,6 +47,10 @@ Trace all open() syscalls:
...
@@ -44,6 +47,10 @@ Trace all open() syscalls:
#
#
.B opensnoop
.B opensnoop
.TP
.TP
Trace all open() syscalls, for 10 seconds only:
#
.B opensnoop -d 10
.TP
Trace all open() syscalls, and include timestamps:
Trace all open() syscalls, and include timestamps:
#
#
.B opensnoop \-T
.B opensnoop \-T
...
...
tools/opensnoop.py
View file @
702de38d
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
# opensnoop Trace open() syscalls.
# opensnoop Trace open() syscalls.
# For Linux, uses BCC, eBPF. Embedded C.
# For Linux, uses BCC, eBPF. Embedded C.
#
#
# USAGE: opensnoop [-h] [-T] [-x] [-p PID] [-t TID] [-n NAME]
# USAGE: opensnoop [-h] [-T] [-x] [-p PID] [-
d DURATION] [-
t TID] [-n NAME]
#
#
# Copyright (c) 2015 Brendan Gregg.
# Copyright (c) 2015 Brendan Gregg.
# Licensed under the Apache License, Version 2.0 (the "License")
# Licensed under the Apache License, Version 2.0 (the "License")
...
@@ -17,6 +17,7 @@ from __future__ import print_function
...
@@ -17,6 +17,7 @@ from __future__ import print_function
from
bcc
import
BPF
from
bcc
import
BPF
import
argparse
import
argparse
import
ctypes
as
ct
import
ctypes
as
ct
from
datetime
import
datetime
,
timedelta
# arguments
# arguments
examples
=
"""examples:
examples
=
"""examples:
...
@@ -25,6 +26,7 @@ examples = """examples:
...
@@ -25,6 +26,7 @@ examples = """examples:
./opensnoop -x # only show failed opens
./opensnoop -x # only show failed opens
./opensnoop -p 181 # only trace PID 181
./opensnoop -p 181 # only trace PID 181
./opensnoop -t 123 # only trace TID 123
./opensnoop -t 123 # only trace TID 123
./opensnoop -d 10 # trace for 10 seconds only
./opensnoop -n main # only print process names containing "main"
./opensnoop -n main # only print process names containing "main"
"""
"""
parser
=
argparse
.
ArgumentParser
(
parser
=
argparse
.
ArgumentParser
(
...
@@ -39,10 +41,14 @@ parser.add_argument("-p", "--pid",
...
@@ -39,10 +41,14 @@ parser.add_argument("-p", "--pid",
help
=
"trace this PID only"
)
help
=
"trace this PID only"
)
parser
.
add_argument
(
"-t"
,
"--tid"
,
parser
.
add_argument
(
"-t"
,
"--tid"
,
help
=
"trace this TID only"
)
help
=
"trace this TID only"
)
parser
.
add_argument
(
"-d"
,
"--duration"
,
help
=
"total duration of trace in seconds"
)
parser
.
add_argument
(
"-n"
,
"--name"
,
parser
.
add_argument
(
"-n"
,
"--name"
,
help
=
"only print process names containing this name"
)
help
=
"only print process names containing this name"
)
args
=
parser
.
parse_args
()
args
=
parser
.
parse_args
()
debug
=
0
debug
=
0
if
args
.
duration
:
args
.
duration
=
timedelta
(
seconds
=
int
(
args
.
duration
))
# define BPF program
# define BPF program
bpf_text
=
"""
bpf_text
=
"""
...
@@ -179,5 +185,6 @@ def print_event(cpu, data, size):
...
@@ -179,5 +185,6 @@ def print_event(cpu, data, size):
# loop with callback to print_event
# loop with callback to print_event
b
[
"events"
].
open_perf_buffer
(
print_event
,
page_cnt
=
64
)
b
[
"events"
].
open_perf_buffer
(
print_event
,
page_cnt
=
64
)
while
1
:
start_time
=
datetime
.
now
()
while
not
args
.
duration
or
datetime
.
now
()
-
start_time
<
args
.
duration
:
b
.
kprobe_poll
()
b
.
kprobe_poll
()
tools/opensnoop_example.txt
View file @
702de38d
...
@@ -89,6 +89,18 @@ The ERR column is the system error number. Error number 2 is ENOENT: no such
...
@@ -89,6 +89,18 @@ The ERR column is the system error number. Error number 2 is ENOENT: no such
file or directory.
file or directory.
A maximum tracing duration can be set with the -d option. For example, to trace
for 2 seconds:
# ./opensnoop -d 2
PID COMM FD ERR PATH
2191 indicator-multi 11 0 /sys/block
2191 indicator-multi 11 0 /sys/block
2191 indicator-multi 11 0 /sys/block
2191 indicator-multi 11 0 /sys/block
2191 indicator-multi 11 0 /sys/block
The -n option can be used to filter on process name using partial matches:
The -n option can be used to filter on process name using partial matches:
# ./opensnoop -n ed
# ./opensnoop -n ed
...
@@ -123,7 +135,7 @@ to the '-n' option.
...
@@ -123,7 +135,7 @@ to the '-n' option.
USAGE message:
USAGE message:
# ./opensnoop -h
# ./opensnoop -h
usage: opensnoop [-h] [-T] [-x] [-p PID] [-t TID] [-n NAME]
usage: opensnoop [-h] [-T] [-x] [-p PID] [-t TID] [-
d DURATION] [-
n NAME]
Trace open() syscalls
Trace open() syscalls
...
@@ -133,6 +145,8 @@ optional arguments:
...
@@ -133,6 +145,8 @@ optional arguments:
-x, --failed only show failed opens
-x, --failed only show failed opens
-p PID, --pid PID trace this PID only
-p PID, --pid PID trace this PID only
-t TID, --tid TID trace this TID only
-t TID, --tid TID trace this TID only
-d DURATION, --duration DURATION
total duration of trace in seconds
-n NAME, --name NAME only print process names containing this name
-n NAME, --name NAME only print process names containing this name
examples:
examples:
...
@@ -141,4 +155,5 @@ examples:
...
@@ -141,4 +155,5 @@ examples:
./opensnoop -x # only show failed opens
./opensnoop -x # only show failed opens
./opensnoop -p 181 # only trace PID 181
./opensnoop -p 181 # only trace PID 181
./opensnoop -t 123 # only trace TID 123
./opensnoop -t 123 # only trace TID 123
./opensnoop -d 10 # trace for 10 seconds only
./opensnoop -n main # only print process names containing "main"
./opensnoop -n main # only print process names containing "main"
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment