icecream-sundae

Commandline Monitor for Icecream

Github stars Tracking Chart

icecream-sundae

Commandline Monitor for Icecream.

Build Status
Codacy Badge
Coverage Status
Snap Status

Icecream Sundae Demo

Installation

Get it from the Snap Store

Building from Source

Prerequsites

Fedora 27 & 28

sudo dnf install gcc-c++ glib2-devel icecream-devel meson ncurses-devel ninja-build

Ubuntu 17.10 (Artful Aardvark) & 18.04 (Bionic Beaver)

sudo apt-get install g++ libcap-ng-dev libglib2.0-dev libicecc-dev liblzo2-dev libncursesw5-dev meson ninja-build

Ubuntu 16.04 (Xenial Xerus)

This version of Ubuntu requires a newer version of meson:

sudo apt-get install g++ libcap-ng-dev libglib2.0-dev libicecc-dev liblzo2-dev libncursesw5-dev meson python3-pip ninja-build
pip3 install --user meson

Ubuntu 14.04 (Trusty Tahr)

While it is possible to install on this ancient version of Ubuntu, it requires a lot of work:

sudo add-apt-repository ppa:jonathonf/python-3.5
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo add-apt-repository ppa:jonathonf/binutils

sudo apt-get update

sudo apt-get install g++-6 libcap-ng-dev libglib2.0-dev libicecc-dev liblzo2-dev libncursesw5-dev python3-pip python3.5 wget unzip

wget https://github.com/ninja-build/ninja/releases/download/v1.8.2/ninja-linux.zip -O ninja-linux.zip
sudo unzip ninja-linux.zip -d /usr/local/bin

python3.5 -m pip install --user meson

export CXX=g++-6

macOS

brew install glib ncurses icecream
export PKG_CONFIG_PATH="/usr/local/opt/ncurses/lib/pkgconfig"

Compiling

To build icecream-sundae, download the latest release, extract it, then run:

mkdir builddir
cd builddir
meson .. --buildtype release
ninja
sudo -E ninja install

Note: For Ubuntu 16.04 & 14.04, you may need to run meson as ~/.local/bin/meson

Running

Simply running icecream-sundae should be sufficent. Without any arguements, the program will try to
discover the default scheduler. For help, run icecream-sundae --help

Display

Columns

The following table describes the columns that are shown for each compile node, Column, Description, ---------------, -----------------------------------------------------------------------------------, ID, The unique ID for the node, as assigned by the scheduler, NAME, The Name of the node. Each node is assigned a color based on a hash of its string name. Nodes that cannot accept remote jobs (i.e. have the "NoRemote" property set to "true") are displayed underlined., IN, The total number of jobs this node has compiled for other nodes, CUR, The current number of jobs this node is compiling, MAX, The maximum number of jobs the node can compile at once, JOBS, A graph of the current jobs (see below), OUT, The total number of jobs this node has sent to other nodes to be compiled remotely, LOCAL, The total number of jobs this node as compiled locally, ACTIVE, The current number of jobs this node has working on the cluster, PENDING, The number of jobs this node has that are waiting to be assigned a node, SPEED, The speed of the node. This is measured by the nodes as the KB/sec of source compiled by the node, ### Job Graphs
Jobs in the job bar graphs are displayed using the following legend:, Character, Meaning, -----------, -----------------------, %, Local compile job, =, Remote compile job, The color of the job marker matches the color of the source node. If the job
graph would be too wide to fit on the screen, it will be scaled down and
enclosed with curly braces {} instead of the normal square braces [].

Note: If there are nodes on the cluster that do not accept remote jobs, it is entirely possible that there can be
more "Active" jobs than "Maximum" slots, if those nodes are doing local compiles

Key bindings, Key(s), Action, -------------------, -------------------------------------------------------, down arrow, j, Move highlight down to next host, up arrow, k, Move highlight up to previous host, left arrow, h, Move sort left one column, right arrow, l, Move sort right one column, tab, Move sort right one column (wraps), space, Toggle host details, a, Toggle all host details, r, Reverse sort, q, Quit, # Notes

C++ is not my most fluent language... Apologies for any travesties I've committed.

TODO

  • User configurable columns (The code supports this, I just need to figure out a good UI)
  • "Managment" interface. It would be nice to be able to blacklist servers and such via a menu that communicates with the scheduler telnet interface
  • Better unit tests
  • Scrolling in the host view

Main metrics

Overview
Name With OwnerJPEWdev/icecream-sundae
Primary LanguageC++
Program languageMeson (Language Count: 4)
Platform
License:GNU General Public License v2.0
所有者活动
Created At2018-04-10 14:09:45
Pushed At2025-01-07 16:24:59
Last Commit At2024-11-15 19:53:31
Release Count1
Last Release Namev1.0.0 (Posted on )
First Release Namev1.0.0 (Posted on )
用户参与
Stargazers Count57
Watchers Count3
Fork Count16
Commits Count57
Has Issues Enabled
Issues Count6
Issue Open Count4
Pull Requests Count5
Pull Requests Open Count1
Pull Requests Close Count2
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private