• Stars
    star
    622
  • Rank 72,195 (Top 2 %)
  • Language
    Python
  • License
    GNU General Publi...
  • Created over 4 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

The top-like text-based user interface for Austin


Austin TUI

A Top-like Interface for Austin

GitHub Actions: Tests
PyPI PyPI Downloads  
LICENSE

Synopsis • Installation • Usage • Compatibility • Contribute

Buy Me A Coffee

Synopsis

The Python TUI is a top-like text-based user interface for Austin, the frame stack sampler for CPython. Originally planned as a sample application to showcase Austin uses, it's been promoted to a full-fledged project thanks to great popularity.

Austin TUI

The header shows you the information of the application that is being profiled, like its PID, the command line used to invoke it, as well as a plot of the amount of CPU and memory that is being used by it, in a system-monitor style.

To know more about how the TUI itself was made, have a read through The Austin TUI Way to Resourceful Text-based User Interfaces.

Installation

Austin TUI can be installed directly from PyPI with

pipx install austin-tui

NOTE In order for the TUI to work, the Austin 3 binary needs to be discoverable in the ways documented by the austin-python library. Have a look at Austin installation instructions to see how you can easily install Austin on your platform.

On macOS and Linux, Austin TUI and its dependencies (including Austin itself) can be installed via conda with

conda install -c conda-forge austin-tui

Usage

Once Austin 3 and Austin TUI are installed, you can start using them straight-away. If you want to launch and profile a Python script, say myscript.py, you can do

austin-tui python3 myscript.py

or, if myscript.py is an executable script,

austin-tui ./myscript.py

Like Austin, the TUI can also attach to a running Python application. To analyse the frame stacks of all the processes of a running WSGI server, for example, get hold of the PID of the parent process and do

sudo austin-tui -Cp <pid>

The -C option will instruct Austin to look for child Python processes, and you will be able to navigate through them with the arrow keys.

The TUI is based on python-curses. The version included with the standard Windows installations of Python is broken so it won't work out of the box. A solution is to install the the wheel of the port to Windows from this page. Wheel files can be installed directly with pip, as described in the linked page.

Thread navigation

Profiling data is processed on a per-thread basis. The total number of threads (across all processes, if sampling child processes) is displayed in the top-right corner of the TUI. To navigate to a different thread, use the and arrows. The PID and TID of the currently selected thread will appear in the middle of the top bar in the TUI.

Full mode

By default, Austin TUI shows you statistics of the last seen stack for each process and thread when the UI is refreshed (about every second). This is similar to what top does with all the running processes on your system.

Austin TUI - Default mode

If you want to see all the collected statistics, with the frame stacks represented as a rooted tree, you can press F to enter the Full mode. The last seen stack will be highlighted so that you also have that information available while in this mode.

Austin TUI - Full mode

The information that gets displayed is very dynamic and could become tricky to inspect. The current view can be paused by pressing P. To resume refreshing the view, press P again. While the view is paused, profiling data is still being captured and processed in the background, so that when the view is resumed, the latest figures are shown.

Graph mode

A live flame graph visualisation of the current thread statistics can be displayed by pressing G. This might help with identifying the largest frames at a glance.

Austin TUI - Live flame graph

To toggle back to the top view, simply press G again.

Save statistics

Peeking at a running Python application is nice but in many cases you would want to save the collected data for further offline analysis (for example, you might want to represent it as a flame graph). At any point, whenever you want to dump the collected data to a file, you can press S and a file with all the samples will be generated for you in the working directory, prefixed with austin_ and followed by a timestamp. The TUI will notify of the successful operation on the bottom-right corner.

Austin TUI - Save notification

If you run the Austin TUI inside VS Code, you can benefit from the editor's terminal features, like using Ctrl/Cmd+Left-Click to hop straight into a source file at a given line. You can also leverage the TUI's save feature to export the collected samples and import them into the Austin VS Code extension to also get a flame graph representation.

Austin TUI

Threshold

The statistics reported by the TUI might be overwhelming, especially in full mode. To reduce the amout of data that gets displayed, the keys + and - can be used to increase or lower the %TOTAL threshold

Austin TUI - Threshold demonstration

Compatibility

Austin TUI has been tested with Python 3.7-3.10 and is known to work on Linux, macOS and Windows.

Since Austin TUI uses Austin to collect samples, the same note applies here:

Due to the System Integrity Protection introduced in macOS with El Capitan, Austin cannot profile Python processes that use an executable located in the /bin folder, even with sudo. Hence, either run the interpreter from a virtual environment or use a Python interpreter that is installed in, e.g., /Applications or via brew with the default prefix (/usr/local). Even in these cases, though, the use of sudo is required.

As for Linux users, the use of sudo can be avoided by granting Austin the cap_sys_ptrace capability with, e.g.

sudo setcap cap_sys_ptrace+ep `which austin`

Contribute

If you like Austin TUI and you find it useful, there are ways for you to contribute.

If you want to help with the development, then have a look at the open issues and have a look at the contributing guidelines before you open a pull request.

You can also contribute to the development of the Austin TUI by becoming a sponsor and/or by buying me a coffee on BMC or by chipping in a few pennies on PayPal.Me.

Buy Me A Coffee

More Repositories

1

austin

Python frame stack sampler for CPython
C
1,413
star
2

pytest-austin

Python Performance Testing with Austin
Python
118
star
3

austin-python

Python wrapper for Austin, the CPython frame stack sampler.
Python
31
star
4

m27q

Simple Python object to control the Gigabyte M27Q OSD settings
Python
28
star
5

austin-vscode

Austin extension for Visual Studio Code
TypeScript
17
star
6

asm

Assembly Code Public Repository
C++
16
star
7

git-railway

🚂💨✨ Visualise local git branches as neat interactive HTML pages
Python
14
star
8

echion

Near-zero-overhead, in-process CPython frame stack sampler with async support
C++
13
star
9

blighty

Desktop Widget Manager. Think of conky, but with Python instead of Lua.
Python
13
star
10

f1-telemetry

F1 telemetry data collection and visualisation
HTML
10
star
11

austin-web

An Austin web interface for remote profiling
Python
7
star
12

spasmlang

Simple Python Assembly Language
Python
7
star
13

dragonfly

Lightweight CPython Debugger
Python
5
star
14

f1-packets

Python library for the official F1 game UDP telemetry data
C
4
star
15

betsy

The incy-wincy Python static dependencies crawler
Python
4
star
16

sibilla

Python ORM for the Oracle database
Python
4
star
17

marvin

Marvin is a collection of machine learning utilities for Python 3.6+
Python
4
star
18

aoc

Advent of Code
HTML
2
star
19

bpf

BPF CO-RE tools
C
2
star
20

erwin

Erwin likes putting stuff in boxes. He's simultaneously useless and useful until you try him.
Python
2
star
21

flamegraph-experiment

Experiment for the paper "On the Algebraic Properties of Flame Graphs" https://arxiv.org/abs/2301.08941
Python
2
star
22

P403n1x87.github.io

The Hub of Heliopolis is the tech bay of http://thenestofheliopolis.blogspot.co.uk/. It is the home of all my experiences with technology that I consider worth sharing to the World.
HTML
1
star
23

jupyter-notebook-launcher

Jupyter Notebook Launcher and Indicator for Ubuntu
Python
1
star
24

dead-bytecode

Backport of bytecode to Python 2
Python
1
star
25

f1-eval

Evaluation race data collector
Python
1
star
26

pi-mcqueen

Code repository for a self-driving toy car project using a single-board computer
Python
1
star
27

gymtax

scripting language interpreter for gym sessions to turn your devices into your personal trainer
Python
1
star
28

podb

Python bytecode-level debugger
Python
1
star