The most commonly used command line tools for process monitoring on Linux are top and its colorful, feature rich cousin htop .
To monitor temperature on Linux, you can use lm-sensors. Similarly, there are many utilities to monitor other real-time metrics such as Disk I/O, Network Stats and others.
Glances is a system monitoring tool which ties them all together and offers a lot more features. What I like the most is that you can use run Glances on a remote Linux server and monitor the system resources on your local system or monitor it through your web browser.
Here’s what it looks like. The terminal in the below screenshot has been beautified with Pywal tool that automatically changes the color based on wallpaper.
You can also integrate it to a tool like Grafana to monitor the stats in an intuitive dashboard.
It is written in Python which means that it can be used on most platforms with almost all features.
Features of Glances
Let’s have a quick glance over the main feature Glances provides (pun intended).
- Can monitor 15+ metrics on a system (including docker containers).
- Flexible usage modes: standalone, client-server, over SSH and web mode.
- Versatile REST API and XML-RPC available for integrations.
- Readily supports exporting data to different services and databases.
- Highly configurable and adaptable to different needs.
- Very comprehensive Documentation.
Installing Glances on Ubuntu and other Linux distributions
Glances is available in the official repositories of many Linux distributions. This means you can use your distribution’s package manager to install it easily.
On Debian/Ubuntu based distributions, you can use the following command:
sudo apt install glances
You can also install the latest Glances using snap package:
sudo snap install glances
Since Glances is based on Python, you can also use PIP to install it on most Linux distributions. Install PIP first and then use it to install Glances:
sudo pip3 install glances
If nothing else, you can always use the auto install script provided by Glances developer. Though we at It’s FOSS don’t recommend running random scripts directly on your system. It’s entirely your decision.
curl -L https://bit.ly/glances | /bin/bash
You can check out other ways to install Glances from their documentation, you can also install it as a docker container.
Using Glances to monitor Linux system resources on local system (standalone mode)
You can easily launch Glances to monitor your local machine by running this command n the terminal.
glances
You can instantly observe that it integrates a lot of different information in one single screen. I like that it shows the public and private IPβs of the computer right at the top.
Glances is also interactive, meaning you can use commands to interact with it while it is running. You can press βsβ to bring up the sensors onto the screen; βkβ to bring up the TCP connections list; β1β to expand the CPU stats to show individual threads.
You can also use the arrow keys to move around the list of processes and sort the table by different metrics.
You can launch Glances with various command line options. There are plenty more interactive commands as well. You can find the complete list in their comprehensive documentation.
Press Ctrl+C to exit Glances.
Using Glances to monitor remote Linux systems (Client – Server mode)
To monitor a remote computer you can use Glances in client-server mode. You need to have Glances installed on both systems.
On the remote Linux system, youβll have to launch glances in server mode using the -s option.
glances -s
On the client system, use this command to launch Glances in client mode and connect to the server.
glances -c server_ip_address
You can also SSH into any computer and launch Glances, which works flawlessly. More information about client-server mode here.
Monitor Linux system resources in web browser using Glances (Web Mode)
Glances can also run in web mode. This means that you can use a web browser to access Glances. Unlike the previous client-server mode, you don’t need to install Glances on the client system.
To start Glances in web mode, use the -w option.
glances -w
Keep in mind that it may display “Glances Web User Interface started on http://0.0.0.0:61208” even on a Linux server when it is actually using the server’s IP address.
The main part is that it uses 61208 port number and you can use it to access Glances via web browser. Just type the server’s IP address followed by the port number like http://123.123.123.123:61208.
You can also use it on the local system using http://0.0.0.0:61208/ or https://localhost:61208/.
The web mode also emulates the terminal look. The web version is built with responsive design principles in mind and looks good even on phones.
You may want to protect the web mode with a password so that only authorized people could use it. The default username is glances.
root@localhost:~# glances -w --password
Define the Glances webserver password (glances username):
Password (confirm):
Do you want to save the password? [Yes/No]: n
Glances Web User Interface started on http://0.0.0.0:61208/
You can find more information on configuring password in the quickstart guide.
Export Glances data to different services
One of the biggest advantage of using Glances is the out of the box support to export data to various databases, services and integration into various data pipelines seamlessly.
You can export to CSV while monitoring with this command.
glances --export csv --export-csv-file /tmp/glances.csv
β/tmp/glances.csvβ is the location of the file. The data is filled in neatly as time series.
You can export to powerful applications like Prometheus to enable conditional triggers and notifications.
It can directly plug into messaging services like RabbitMQ, MQTT, streaming platforms like Kafka and export time series data to databases like InfluxDB and visualize using Grafana.
You can check out the whole list of services and export options here.
Use REST API to integrate Glances with other services
This is my favorite feature in the whole stack. Glances not only brings together various metrics together, it also exposes them via APIs.
This simple yet powerful feature makes it very easy to build custom applications, services and middleware applications for any specific use cases.
REST API server stars automatically when you launch Glances in web mode. To launch it in API server only mode you can use the following command.
glances -w --disable-webui
The REST API documentation is comprehensive and the responses are easy to integrate with a web application. This makes it easy to build a unified dashboard to monitor multiple servers with a tool like Node-RED.
Glances also provides an XML-RPC server, you can check out the documentation here.
Closing thoughts on Glances
Glances uses the psutil python library to access different system stats. I had built a simple API server using the same library to retrieve CPU usage back in 2017. I was able to monitor all the Raspberry Piβs in a cluster using a dashboard built with Node-RED.
Glances could have saved me some time while offering way more features, unfortunately I didnβt know about it back then.
I did try to install Glances on my Raspberry Piβs while writing this article, unfortunately it failed with some errors with all the installation methods. Iβll update the article when I succeed or maybe write another article with steps to install on a Raspberry Pi.
I wish Glances offered a way to kill processes like top or htop. Let’s hope that we get it in upcoming releases.
I hope this gave you a good deal of information on Glances. What system monitoring tools do you guys use? let me know in the comments.