Linux: Keep An Eye On Your System With Glances Monitor

I

s there is a tool that can provide me a maximum of information (such as cpu, disk I/O, network, nfsd, memory and more) about my Linux/Unix server in a minimum of space in a terminal?

 

There are plenty of monitoring tools on Linux or Unix-like systems that can provide information about your server:

CPU load

OS Name/Kernel version

System load

Disk and Network I/O

Process

Memory usage

Mount point and much more.

Say hello to Glances

From the project home page:

Glances is a free (LGPL) cross-platform curses-based monitoring tool which aims to present a maximum of information in a minimum of space, ideally to fit in a classical 80×24 terminal or higher to have additionnal information. Glances can adapt dynamically the displayed information depending on the terminal size. It can also work in a client/server mode for remote monitoring.

This utility is written in Python and uses the psutil library to fetch the statistical values from your server.

Installation

You can install Glances using pip command line tool. You will also find packages for Arch Linux, Fedora/CentOS/RHEL, Debian, Ubuntu (13.04+), FreeBSD, OSX and so you should be able to install it using your favorite package manager as follows:

Install Glances on CentOS/Fedora/RHEL/Scientific Linux

First, turn on Extra Packages for Enterprise Linux (or EPEL) repo on CentOS/RHEL/SL. Type the following yum command:

# yum -y install glances

 

Sample outputs:

yum install glances

Loaded plugins: product-id, protectbase, rhnplugin

This system is receiving updates from RHN Classic or RHN Satellite.

rhel-x86_64-server-6                                 | 1.5 kB     00:00

rhel-x86_64-server-optional-6                        | 1.5 kB     00:00

0 packages excluded due to repository protections

Setting up Install Process

Resolving Dependencies

–> Running transaction check

—> Package glances.noarch 0:1.7.1-1.el6 will be installed

–> Processing Dependency: python-psutil >= 0.4.1 for package: glances-1.7.1-1.el6.noarch

–> Processing Dependency: python-setuptools for package: glances-1.7.1-1.el6.noarch

–> Running transaction check

—> Package python-psutil.x86_64 0:0.6.1-1.el6 will be installed

—> Package python-setuptools.noarch 0:0.6.10-3.el6 will be installed

–> Finished Dependency Resolution

 

Dependencies Resolved

 

============================================================================

Package             Arch     Version          Repository              Size

============================================================================

Installing:

glances             noarch   1.7.1-1.el6      epel                   107 k

Installing for dependencies:

python-psutil       x86_64   0.6.1-1.el6      epel                    84 k

python-setuptools   noarch   0.6.10-3.el6     rhel-x86_64-server-6   336 k

 

Transaction Summary

============================================================================

Install       3 Package(s)

 

Total download size: 527 k

Installed size: 843 k

Is this ok [y/N]: y

Downloading Packages:

(1/3): glances-1.7.1-1.el6.noarch.rpm                | 107 kB     00:00

(2/3): python-psutil-0.6.1-1.el6.x86_64.rpm          |  84 kB     00:00

(3/3): python-setuptools-0.6.10-3.el6.noarch.rpm     | 336 kB     00:00


Total                                       1.8 MB/s | 527 kB     00:00

Running rpm_check_debug

Running Transaction Test

Transaction Test Succeeded

Running Transaction

Installing : python-psutil-0.6.1-1.el6.x86_64                         1/3

Installing : python-setuptools-0.6.10-3.el6.noarch                    2/3

Installing : glances-1.7.1-1.el6.noarch                               3/3

Verifying  : python-setuptools-0.6.10-3.el6.noarch                    1/3

Verifying  : python-psutil-0.6.1-1.el6.x86_64                         2/3

Verifying  : glances-1.7.1-1.el6.noarch                               3/3

 

Installed:

glances.noarch 0:1.7.1-1.el6

 

Dependency Installed:

python-psutil.x86_64 0:0.6.1-1.el6

python-setuptools.noarch 0:0.6.10-3.el6

 

Complete!

Install Glances on Debian/Ubuntu Linux (13.04+)

Type the following command:

$ sudo apt-get install glances

 

Sample outputs:

Reading package lists… Done

Building dependency tree

Reading state information… Done

The following extra packages will be installed:

python-jinja2 python-markupsafe python-psutil

Suggested packages:

python-jinja2-doc

The following NEW packages will be installed:

glances python-jinja2 python-markupsafe python-psutil

0 upgraded, 4 newly installed, 0 to remove and 0 not upgraded.

Need to get 734 kB of archives.

After this operation, 2,429 kB of additional disk space will be used.

Do you want to continue? [Y/n]

Get:1 http://mirrors.service.networklayer.com/ubuntu/ trusty/main python-markupsafe amd64 0.18-1build2 [14.3 kB]

Get:2 http://mirrors.service.networklayer.com/ubuntu/ trusty/main python-jinja2 all 2.7.2-2 [161 kB]

Get:3 http://mirrors.service.networklayer.com/ubuntu/ trusty/main python-psutil amd64 1.2.1-1ubuntu2 [50.2 kB]

Get:4 http://mirrors.service.networklayer.com/ubuntu/ trusty/universe glances all 1.7.3-2ubuntu1 [509 kB]

Fetched 734 kB in 0s (6,667 kB/s)

Selecting previously unselected package python-markupsafe.

(Reading database … 64983 files and directories currently installed.)

Preparing to unpack …/python-markupsafe_0.18-1build2_amd64.deb …

Unpacking python-markupsafe (0.18-1build2) …

Selecting previously unselected package python-jinja2.

Preparing to unpack …/python-jinja2_2.7.2-2_all.deb …

Unpacking python-jinja2 (2.7.2-2) …

Selecting previously unselected package python-psutil.

Preparing to unpack …/python-psutil_1.2.1-1ubuntu2_amd64.deb …

Unpacking python-psutil (1.2.1-1ubuntu2) …

Selecting previously unselected package glances.

Preparing to unpack …/glances_1.7.3-2ubuntu1_all.deb …

Unpacking glances (1.7.3-2ubuntu1) …

Processing triggers for ureadahead (0.100.0-16) …

ureadahead will be reprofiled on next reboot

Processing triggers for man-db (2.6.7.1-1ubuntu1) …

Setting up python-markupsafe (0.18-1build2) …

Setting up python-jinja2 (2.7.2-2) …

Setting up python-psutil (1.2.1-1ubuntu2) …

Setting up glances (1.7.3-2ubuntu1) …

Creating system user  glances .

* Starting Glances server glances                                                                                  * Not starting glances: disabled by /etc/default/glances.

Processing triggers for ureadahead (0.100.0-16) …

Turn on glances by editing the /etc/default/glances file, enter:

# vi /etc/default/glances

 

Update it as follows to ‘true’ to have glances running at startup:

RUN= true

Save and close the file. Start glances:

# service glances start

How do I use glances?

The basic syntax is:

# glances

# glances [options]

 

Sample outputs:

Fig.01: glances in action (click to enlarge)

 

To quit just press q (Esc and Ctrl-C also work). Here is another output from Ubuntu based system:

Fig.02: Glances in action (Image credit – Glances author)

HTML5 capable browser user can view quick video demo by clicking the following link:

Sorry, your browser doesn’t support HTML5 video.

(Video 01: Glances command in action)

Fine tuning output (interactive commands)

Use the following hot keys to find tune your output:

a Sort processes automatically.

c Sort processes by CPU%.

m Sort processes by MEM%.

p Sort processes by name.

i Sort processes by I/O rate.

d Show/hide disk I/O stats.

f Show/hide file system stats.

n Show/hide network stats.

s Show/hide sensors stats.

y Show/hide hddtemp stats.

l Show/hide logs.

b Bytes or bits for network I/O.

w Delete warning logs.

x Delete warning and critical logs.

1 Global CPU or per-CPU stats.

t View network I/O as combination.

u – View cumulative network I/O.

How do I use Glances in client/server mode?

On server type the following command to bind server to the given IPv4/IPv6 address or hostname:

# glances -B @IP|host

# glances -B 75.126.153.206

# glances -B www.cyberciti.biz

 

From your desktop client such as OSX/FreeBSD/Linux based system type the following command to connect to a Glances server by IPv4/IPv6 address or hostname:

# glances -c @IP|host

# glances -c 75.126.153.206

# glances -c www.cyberciti.biz

 

You may need to pass the -P password to set a client/server password. The -s run Glances in server mode:

How do I refresh information every 5 seconds?

Type the following command:

# glances -t 5

How do I see all supported options?

This command has many more options, type the following command at shell prompt:

$ glances -h

 

Sample outputs:

Glances version 1.7.3 with PsUtil 1.2.1

Usage: glances [options]

 

Options:

-b  Display network rate in Byte per second

-B @IP|HOST Bind server to the given IPv4/IPv6 address or hostname

-c @IP|HOST Connect to a Glances server by IPv4/IPv6 address or hostname

-C FILE  Path to the configuration file

-d  Disable disk I/O module

-e  Enable sensors module

-f FILE  Set the HTML output folder or CSV file

-h  Display the help and exit

-m  Disable mount module

-n  Disable network module

-o OUTPUT Define additional output (available: HTML or CSV)

-p PORT  Define the client/server TCP port (default: 61209)

-P PASSWORD Define a client/server password

–password Define a client/server password from the prompt

-r  Disable process list

-s  Run Glances in server mode

-t SECONDS Set refresh time in seconds (default: 3 sec)

-v  Display the version and exit

-y  Enable hddtemp module

-z  Do not use the bold color attribute

-1  Start Glances in per CPU mode

See also

Glances is not the only option. You can try:

How to install and use atop – an advanced system & process monitor.

How to install and use htop – an interactive process viewer.

Linux: Find Out What Process Are Using Swap Space

Install and Use nmon Tool To Monitor Linux Systems Performance

Top 20 recommend old good Linux and Unix system monitoring tool such as top, vmstat, mpstat, ps, iostat, sar, pmap and more.

Glances project home page or try pypi Glances repo for more info.

Linux: Monitor Hard Disks Temperature With hddtemp.

Man page: glances(1)

 

 

Leave a Reply

Your email address will not be published. Required fields are marked *