Skip to main content

A simple system information tool for Linux

Project description

python-SysInformer

The python-SysInformer is a system information tool that allows users to retrieve various types of information about their system. It offers functionalities to gather CPU details, memory information, disk space usage, network activity, process status, container information, and system statistics such as OS type, uptime, and hostname.

Why another system information tool?

Numerous system information tools, like htop, glances, and neofetch, serve Linux systems. While they're excellent, this tool isn't meant to replace them. Instead, it simplifies retrieving both critical and occasional system details. For instance, to quickly find a host IP, instead of using ip a and potentially adding grep, you can now utilize psi run -n. Similarly, to check container ports, the lengthy docker ps command can be swapped for psi -ct.

Additionally, this project is my venture to enhance my Python capabilities. While not a developer, I frequently script and automate tasks. I've been using Python for a few months now, but I've never really taken the time to learn the language. I've always just learned what I needed to get the job done. I've been wanting to change that and this project is my first attempt at doing so. I'm sure there are many things that could be done better, but I'm happy with the progress I've made and the knowledge I've gained so far.

Features

The following gif demonstrates some of the tool's features:

psi-gif

Getting Started

Prerequisites

The tool requires Python 3.11 or higher. Additionally, the tool is inteneded to be used on Linux and macOS systems. The tool is not intended to be used on Windows systems.

Dependencies

The tool uses the following Python packages:

  • distro
  • netifaces
  • ping3
  • psutil
  • PyYAML
  • tabulate

Installation

The easiest way to install the tool is with pip:

  pip install python-SysInformer

  # if using pyenv - upgrade the tool with to avoid potential cache issues:
  pip install --upgrade python-SysInformer --force-reinstall

Additionaly, if you have poetry installed you can install the tool with:

git clone [this repo]
poetry install

# OR

poetry add python-SysInformer

Finally, you can install the tool from source:

git clone [this repo]
pip install -r requirements.txt

Usage

The tool is intended to be used as a command line tool:

Usage: psi [OPTIONS] COMMAND [ARGS]...

  System information tool.

Options:
  --help  Show this message and exit.

Commands:
  config   The config command is used to create a default config file.
  run      The run command is the main command for the tool.
  version  Prints the version of the tool.

The most basic usage to retrieve all information is:

psi run -a

If you prefer to only retrieve specific information, you can use the following options:

Options:
  -a, --all           Show all information
  -s, --system        Show only system information
  -c, --cpu           Show only CPU information
  -m, --memory        Show only memory information
  -d, --disk          Show only disk information
  -n, --network       Show only network and latency information
  -ps, --processes    Show only services information
  -ct, --containers   Show only running container (docker or podman)
                      information

Configuration

You can configure the tool using a YAML file. Currently, the configuration options allow you to specify services and ports to monitor for their operational status, and set targets to ping to measure latency.

A default configuration file can be created using the psi config --create command. By default, the configuration file is located at ~/.config/psi/config.yaml. If you'd like to use a different location, simply provide the path using the --config-path e.g. psi config --create --config-path /some/path/config.yaml. You can then pass the path to the psi run command using the same option.

The config file itself is fairly basic and looks like this:

services:
  - name: FTP Server
    port: 21
    host: localhost
  - name: SSH
    port: 22
    host: localhost
  - name: HTTP
    port: 80
    host: localhost
  - name: HTTPS
    port: 443
    host: localhost
  - name: MySQL Server
    port: 3306
    host: localhost
  - name: PostgreSQL Server
    port: 5432
    host: localhost

ping_hosts:
  - google.com
  - timothybryantjr.com
  - github.com

Note: The tool will still run without a config file, but will not be able to check up or down status for services or ping targets for latency information.

Acknowledgements

This tool was inspired by eZ Server Monitor. Specfically, their eSMsh feature which allows users to retrieve system information from the command line via a bash script. In fact, if you want the portability of a bash script, I would recommend using eSMsh. I'm not sure if the script is still being maintained, but it is still available on Github. But if you don't mind using Python, and want a little more information, then the python-SysInformer tool could be for you.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python_sysinformer-1.10.1.tar.gz (29.6 kB view details)

Uploaded Source

Built Distribution

python_sysinformer-1.10.1-py3-none-any.whl (33.5 kB view details)

Uploaded Python 3

File details

Details for the file python_sysinformer-1.10.1.tar.gz.

File metadata

  • Download URL: python_sysinformer-1.10.1.tar.gz
  • Upload date:
  • Size: 29.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for python_sysinformer-1.10.1.tar.gz
Algorithm Hash digest
SHA256 36d5cd9f6a240fd0f4a26374e625911e43e77823a020bb498b777e4e58a6482a
MD5 b6f3527a17bfa1f9ac58c1390f356cbf
BLAKE2b-256 c8df9b5d5ababdf0ae7e009eae018ff54c38909bc2e103a2eb1f880f2369c281

See more details on using hashes here.

File details

Details for the file python_sysinformer-1.10.1-py3-none-any.whl.

File metadata

File hashes

Hashes for python_sysinformer-1.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4067515e93b9abc38e17c624d06eda82a992c96ada65ab79bf4bcae13022fc44
MD5 f7f7205a1a01eefbdff3151387b1434a
BLAKE2b-256 66ecc2983394fdb7f8997c585bf687adb82465542a1f0bb0a170e9e6aae5059d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page