icecream-sundae

Commandline Monitor for Icecream

Github星跟蹤圖

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

主要指標

概覽
名稱與所有者JPEWdev/icecream-sundae
主編程語言C++
編程語言Meson (語言數: 3)
平台
許可證GNU General Public License v2.0
所有者活动
創建於2018-04-10 14:09:45
推送於2025-07-18 16:04:18
最后一次提交2025-07-18 10:03:14
發布數2
最新版本名稱v1.1.0 (發布於 )
第一版名稱v1.0.0 (發布於 )
用户参与
星數59
關注者數3
派生數17
提交數60
已啟用問題?
問題數8
打開的問題數5
拉請求數5
打開的拉請求數2
關閉的拉請求數2
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?