Skip to content

Commit

Permalink
use new event_re option to improve vfscount
Browse files Browse the repository at this point in the history
  • Loading branch information
brendangregg committed Aug 29, 2015
1 parent ab4ca4c commit 4cbdef7
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 25 deletions.
16 changes: 9 additions & 7 deletions man/man8/vfscount.8
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
.TH vfscount 8 "2015-08-18" "USER COMMANDS"
.SH NAME
vfscount \- Count some common VFS calls. Uses Linux eBPF/bcc.
vfscount \- Count VFS calls ("vfs_*"). Uses Linux eBPF/bcc.
.SH SYNOPSIS
.B vfscount
.SH DESCRIPTION
This counts common VFS calls. This can be useful for general workload
This counts VFS calls. This can be useful for general workload
characterization of these operations.

This works by tracing some kernel vfs functions using dynamic tracing, and will
need updating to match any changes to these functions. Edit the script to
customize and add functions to trace, which is easy to do.
This works by tracing all kernel functions beginning with "vfs_" using dynamic
tracing. This may match more functions than you are interested in measuring:
Edit the script to customize which functions to trace.

Since this uses BPF, only the root user can use this tool.
.SH REQUIREMENTS
Expand All @@ -30,11 +30,13 @@ Kernel function name
COUNT
Number of calls while tracing
.SH OVERHEAD
This traces various kernel vfs functions and maintains in-kernel counts, which
This traces kernel vfs functions and maintains in-kernel counts, which
are asynchronously copied to user-space. While the rate of VFS operations can
be very high (>1M/sec), this is a relatively efficient way to trace these
events, and so the overhead is expected to be small for normal workloads.
Measure in a test environment.
Measure in a test environment, and if overheads are an issue, edit the script
to reduce the types of vfs functions traced (currently all beginning with
"vfs_").
.SH SOURCE
This is from bcc.
.IP
Expand Down
21 changes: 10 additions & 11 deletions tools/vfscount
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/python
#
# vfscount Count some VFS calls.
# vfscount Count VFS calls ("vfs_*").
# For Linux, uses BCC, eBPF. See .c file.
#
# Written as a basic example of counting functions.
Expand Down Expand Up @@ -36,7 +36,7 @@ def load_kallsyms():
ksym_addrs.append(addr)
ksym_names.append(name)
syms.close()
def ksym(addr):
def _ksym_addr2index(addr):
start = -1
end = len(ksym_addrs)
while end != start + 1:
Expand All @@ -45,18 +45,17 @@ def ksym(addr):
end = mid
else:
start = mid
if start == -1:
return start
def ksym(addr):
idx = _ksym_addr2index(addr)
if idx == -1:
return "[unknown]"
return ksym_names[start]
return ksym_names[idx]
load_kallsyms()

# load BPF program
b = BPF(src_file = "vfscount.c")
b.attach_kprobe(event="vfs_read", fn_name="do_count")
b.attach_kprobe(event="vfs_write", fn_name="do_count")
b.attach_kprobe(event="vfs_fsync", fn_name="do_count")
b.attach_kprobe(event="vfs_open", fn_name="do_count")
b.attach_kprobe(event="vfs_create", fn_name="do_count")
b.attach_kprobe(event_re="^vfs_.*", fn_name="do_count")

# header
print("Tracing... Ctrl-C to end.")
Expand All @@ -67,7 +66,7 @@ try:
except KeyboardInterrupt:
pass

print("\n%-16s %-12s %8s" % ("ADDR", "FUNC", "COUNT"))
print("\n%-16s %-26s %8s" % ("ADDR", "FUNC", "COUNT"))
counts = b.get_table("counts")
for k, v in sorted(counts.items(), key=lambda counts: counts[1].value):
print("%-16x %-12s %8d" % (k.ip, ksym(k.ip), v.value))
print("%-16x %-26s %8d" % (k.ip, ksym(k.ip), v.value))
23 changes: 16 additions & 7 deletions tools/vfscount_example.txt
Original file line number Diff line number Diff line change
@@ -1,17 +1,26 @@
Demonstrations of vfscount, the Linux eBPF/bcc version.


This counts VFS calls, by tracing various kernel calls beginning with "vfs_"
(edit the script to customize):
This counts VFS calls, by tracing all kernel functions beginning with "vfs_":

# ./vfscount
Tracing... Ctrl-C to end.
^C
ADDR FUNC COUNT
ffffffff811f2cc1 vfs_create 24
ffffffff811e71c1 vfs_write 203
ffffffff811e6061 vfs_open 765
ffffffff811e7091 vfs_read 1852
ADDR FUNC COUNT
ffffffff811f3c01 vfs_create 1
ffffffff8120be71 vfs_getxattr 2
ffffffff811f5f61 vfs_unlink 2
ffffffff81236ca1 vfs_lock_file 6
ffffffff81218fb1 vfs_fsync_range 6
ffffffff811ecaf1 vfs_fstat 319
ffffffff811e6f01 vfs_open 475
ffffffff811ecb51 vfs_fstatat 488
ffffffff811ecac1 vfs_getattr 704
ffffffff811ec9f1 vfs_getattr_nosec 704
ffffffff811e80a1 vfs_write 1764
ffffffff811e7f71 vfs_read 2283

This can be useful for workload characterization, to see what types of
operations are in use.

You can edit the script to customize what kernel functions are matched.

0 comments on commit 4cbdef7

Please sign in to comment.