NetHogs: Network Bandwidth Monitoring Tool in Linux

Linux TLDR
Last Updated:
Reading time: 2 minutes

NetHogs is a lightweight, open-source network bandwidth monitoring tool (similar to Top for process monitoring) that can help you identify the process or application consuming the most network traffic bandwidth in real-time.

All detected processes will be listed with their PID, owner, program (PATH, IP address, or hostname), sent and received data, and, unlike other network monitoring tools, it does not rely on any special kernel module.

It can be used in various scenarios, such as if there is a sudden spike in network traffic that seems unusual; you can initiate NetHogs to find the source of this issue and take further action.

In today’s article, you’ll learn how to install NetHogs on the most popular Linux distribution and its command-line usage with a practical example.

Tutorial Details

DescriptionNetHogs: Network Bandwidth Monitoring Tool
Difficulty LevelLow
Root or Sudo PrivilegesYes
OS CompatibilityUbuntu, Manjaro, Fedora, etc.
Prerequisites–
Internet RequiredYes (for installation)

How to Install NetHogs on Linux

The NetHogs can be easily installed in most Linux distributions with the default package manager by running one of the appropriate commands.

#On Debian and Ubuntu
$ sudo apt install nethogs

#On RedHat and CentOS
$ sudo yum install epel-release
$ sudo yum install nethogs

#On Fedora
$ sudo dnf install nethogs

#On Arch and Manjaro
$ sudo pacman -S nethogs

#On OpenSUSE
$ sudo zypper i nethogs

#On Alpine Linux
$ sudo apk add nethogs

Usage of NetHogs

After the installation is complete, you can access the β€œnethogs” command with or without specifying the interface (autodetected if left empty), but ensure to run the command with root or sudo privileges.

$ sudo nethogs

#OR

$ sudo nethogs [interface1] [interface2]

If there is no network activity in the background when you launch it, you will receive the following stale output:

nethogs output without network activity

For demonstration purposes, I’ve initiated a system update in the background, and once there is certain network activity, NetHogs will start reporting it in real-time.

nethogs output with network activity

As you can see, each process is listed in rows along with its respective PID, owner, program, device, sent, and received data that you can use for your investigation.

The following are a few keyboard shortcuts that you can use in NetHogs.

KeyUsage
mCycle between (KB/s, MB/s, GB/s) modes in the sent and received columns.
sSort by sent traffic.
rSort by received traffic.
qQuit and return to the shell prompt.

The following are options that you can use with NetHogs:

OptionDescription
-dSet time interval for refresh (default is 1 for 1 second).
-vSet mode for send and receive columns (0 = KB/s (default), 1 = total KB, 2 = total B, 3 = total MB, 4 = MB/s, 5 = GB/s).
-cSet the number of updates (default is 0 for ulimited).
-tTracemode.
-sSort output by sent column.
-rSort output by received column.
-aMonitor all devices, including loopbacks and stopped ones.
-CCapture UDP and TCP traffic.
-hPrint the help.

As you can see, it’s a very basic command-line tool, but it can be very helpful sometimes. If you have any questions or queries related to the topic, then do let me know in the comment section.

Till then, peace!

Join The Conversation

Users are always welcome to leave comments about the articles, whether they are questions, comments, constructive criticism, old information, or notices of typos. Please keep in mind that all comments are moderated according to our comment policy.