Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/goldshtn/linux-tracing-workshop

Examples and hands-on labs for Linux tracing tools workshops
https://github.com/goldshtn/linux-tracing-workshop

Last synced: about 2 months ago
JSON representation

Examples and hands-on labs for Linux tracing tools workshops

Awesome Lists containing this project

README

        

### Linux Tracing Workshops Materials

This repository contains examples and hands-on labs for various Linux tracing workshops, focusing on modern tracing tools. To perform these labs, you will need a Linux box that meets several prerequisites. You can also use an EC2 instance supplied by the instructor.

- - -

#### Prerequisites

1. Linux 4.6+ (the distribution doesn't matter; tested on Ubuntu and Fedora Core)
1. [perf](https://perf.wiki.kernel.org/index.php/Main_Page)
1. [perf-map-agent](https://github.com/jrudolph/perf-map-agent)
1. [FlameGraph](https://github.com/brendangregg/FlameGraph)
1. [perf-tools](https://github.com/brendangregg/perf-tools)
1. [bcc](https://github.com/iovisor/bcc/blob/master/INSTALL.md)
1. [OpenJDK](http://openjdk.java.net)
1. The **systemtap-sdt-dev** package on Ubuntu or the **systemtap-sdt-devel** package on Fedora/RHEL
1. [Node.js](https://github.com/nodejs/node/wiki/Installation) built from source with `configure --with-dtrace`
1. MySQL or [MariaDB](https://mariadb.org) built from source with `-DENABLE_DTRACE=1`
1. PostgreSQL built from [source](https://github.com/postgres/postgres) with `configure --enable-dtrace`
1. [MySQL Python Connector](https://dev.mysql.com/doc/connector-python/en/connector-python-installation.html)

If you're using Fedora 24+, try the experimental [setup script](setup-fedora.sh), which can fetch you a recent kernel from mainline and install all the packages and tools you need for this workshop. Use at your own risk!

- - -

#### Strigo Virtual Environment

When this workshop is delivered as instructor-led training, the instructor will provision a Strigo virtual classroom (EC2 instances) for each student. To use the Strigo virtual environment:

1. Log in to Strigo using the link provided by the instructor (you can log in with Google or create a new account, no verification required)
1. Enter the classroom token (four characters) provided by the instructor to join the classroom
1. Navigate to the Lab tab (fourth from the top, the icon that looks like a test tube) to get your EC2 instance started

- - -

#### Labs

1. [Probing Tracepoints with ftrace](ftrace.md)
1. [CPU Sampling with `perf` and Flame Graphs](perf.md)
1. [Using BPF Tools: Broken File Opens](bpf-opens.md)
1. [Using BPF Tools: Slow File I/O](bpf-files.md)
1. [Using BPF Tools: Chasing a Memory Leak](bpf-memleak.md)
1. [Using BPF Tools: Database and Disk Stats and Stacks](bpf-io.md)
1. [Using BPF Tools: Node and JVM USDT Probes](bpf-usdt.md)
1. [Writing BPF Tools: `setuidsnoop`](bpf-setuidsnoop.md)
1. [Writing BPF Tools: `dbslower`](bpf-dbslower.md)
1. [Writing BPF Tools: Contention Stats and Stacks](bpf-contention.md)
1. [Writing BPF Tools: From BCC GitHub Issues](bpf-issues.md)
1. [Using `perf` Tools: Broken File Opens](perf-opens.md)
1. [Using BPF Tools: `trace` and `argdist` One-Liners](bpf-oneliners.md)
1. [Using BPF Tools: CPU and Off-CPU Investigation](bpf-cpu.md)
1. [Using `perf` Tools: Slow File I/O](perf-io.md)
1. [Using BPF Tools: Node Blocked Time Analysis](bpf-nodeblocked.md)
1. [Using BPF Tools: Node Garbage Collections](bpf-nodegc.md)
1. [Using BPF Tools: Node File Opens](bpf-nodeopens.md)
1. [Using BPF Tools: Node Slow MySQL Queries](bpf-nodemysql.md)
1. [Node Profiling with V8](node-prof.md)
1. [Node Core Dump Analysis with `llnode`](node-coredump.md)
1. [Node Memory Leak Analysis](node-memleak.md)
1. [Node Slow HTTP Requests](node-slowhttp.md)
1. [Node Slow DNS](node-slowdns.md)
1. [Node Leaky Slowdown](node-slowdown.md)

- - -

(C) Sasha Goldshtein, 2015-2017. All rights reserved.