Ansible role for installing ctop the top for Docker
Go to file
John Freeman 4d7cfee32d
Refactored to reuse release workflow (#56)
For better code reuse.
2022-08-03 22:48:46 +01:00
.github/workflows Refactored to reuse release workflow (#56) 2022-08-03 22:48:46 +01:00
.moleculew Upgraded test Python version to 3.8.10 (#53) 2022-05-22 10:49:11 +01:00
defaults Updated ctop to 0.7.7 (#45) 2022-03-29 07:29:23 +01:00
handlers Implemented ctop role (#1) 2018-08-26 15:22:30 +01:00
meta Increased minimum Ansible version to 2.9 (#47) 2022-05-02 10:34:21 +01:00
molecule Removed unused test dockerfile config (#44) 2022-01-22 20:00:12 +00:00
tasks Implemented ctop role (#1) 2018-08-26 15:22:30 +01:00
vars Updated ctop to 0.7.7 (#45) 2022-03-29 07:29:23 +01:00
.editorconfig Added .editorconfig file 2018-08-26 11:10:47 +00:00
.gitattributes Added .gitattributes 2018-08-26 11:09:59 +00:00
.gitignore Added .gitignore 2018-08-26 11:10:21 +00:00
.yamllint Updated Molecule to 2.22 (#14) 2019-10-18 18:13:57 +01:00
LICENSE Initial commit 2018-08-26 12:06:57 +01:00
README.md Increased minimum Ansible version to 2.9 (#47) 2022-05-02 10:34:21 +01:00
moleculew Updated moleculew to version 1.2.0 (#51) 2022-05-15 09:40:28 +01:00

README.md

Ansible Role: ctop

Tests Ansible Galaxy License

Role to download and install ctop the top-like interface for container metrics. View CPU, RAM and network I/O for your Docker containers at a glance from your terminal.

Requirements

  • Ansible >= 2.9

  • Linux Distribution

    • Debian Family

      • Debian

        • Stretch (9)
        • Buster (10)
        • Bullseye (11)
      • Ubuntu

        • Bionic (18.04)
        • Focal (20.04)
    • RedHat Family

      • Rocky Linux

        • 8
      • Fedora

        • 35
    • SUSE Family

      • openSUSE

        • 15.3
    • Note: other versions are likely to work but have not been tested.

  • Docker (already installed)

Role Variables

The following variables will change the behavior of this role (default values are shown below):

# ctop version number
ctop_version: '0.7.7'

# SHA256 sum for the ctop redistributable
ctop_redis_sha256sum: 'b78374734ebe3d14b6edee3d5512c911c250d7fa7f3f964cb00acd3bc5a02a09'

# Directory to store files downloaded for ctop
ctop_download_dir: "{{ x_ansible_download_dir | default(ansible_env.HOME + '/.ansible/tmp/downloads') }}"

Example Playbook

- hosts: servers
  roles:
    - role: gantsign.ctop

Tab Completion for Zsh

Using Ansible

We recommend using the gantsign.antigen role to enable tab completion for ctop (this must be configured for each user).

- hosts: servers
  roles:
    - role: gantsign.ctop

    - role: gantsign.antigen
      users:
        - username: example
          antigen_bundles:
            - name: ctop
              url: gantsign/zsh-plugins
              location: ctop

Using Antigen

If you prefer to use Antigen directly add the following to your Antigen configuration:

antigen bundle gantsign/zsh-plugins ctop

More Roles From GantSign

You can find more roles from GantSign on Ansible Galaxy.

Development & Testing

This project uses Molecule to aid in the development and testing; the role is unit tested using Testinfra and pytest.

To develop or test you'll need to have installed the following:

Because the above can be tricky to install, this project includes Molecule Wrapper. Molecule Wrapper is a shell script that installs Molecule and it's dependencies (apart from Linux) and then executes Molecule with the command you pass it.

To test this role using Molecule Wrapper run the following command from the project root:

./moleculew test

Note: some of the dependencies need sudo permission to install.

License

MIT

Author Information

John Freeman

GantSign Ltd. Company No. 06109112 (registered in England)