22 releases (12 stable)

new 1.8.0 Jan 9, 2025
1.7.0 Jan 3, 2025
1.6.2 Dec 31, 2024
1.3.1 Nov 29, 2024
0.0.2 Jun 18, 2024

#23 in Unix APIs

Download history 1/week @ 2024-09-22 144/week @ 2024-09-29 203/week @ 2024-10-06 111/week @ 2024-10-13 167/week @ 2024-10-20 130/week @ 2024-10-27 84/week @ 2024-11-03 139/week @ 2024-11-10 123/week @ 2024-11-17 254/week @ 2024-11-24 184/week @ 2024-12-01 41/week @ 2024-12-08 284/week @ 2024-12-15 85/week @ 2024-12-22 305/week @ 2024-12-29 160/week @ 2025-01-05

835 downloads per month

GPL-3.0-or-later

335KB
9K SLoC

SysD Manager

This application exists to easily allow user to manage their systemd units via a GUI. Not only are you able to make changes to the enablement and running status of each of the units, but you will also be able to view and modify their unit files and check the journal logs.

Disclaimer

This application is not intended to a profesional system administrator audience.

If you consider yourself an administator, please refer to systemctl and journalctl documentation.

Features

Here are Sysd Manager main features :

  • Unit file browser with serach and filtering
  • Enable or disable a unit
  • Activate or desactivate a unit
  • View and modify unit file
  • View and navigate unit's dependencies
  • Unit file syntax highlighting
  • Journal file syntax highlighting
  • List of all running units, ordered by the time they took to initialize systemd-analyze blame
  • Follow Dark and Light style switching
  • Select a unit at program opening by passing a unit name as cli argument (see --help)

Note if you need a feature communicate with the author or contribute to the project. If you're stuck take a look at systemctl.

Requirement

Any Linux distribution that has adopted systemd.

Screenshots

Unit Info

Unit Info

Unit Files

Unit Journal

Analyze Blame

Credit

This project is inspired by the work of Guillaume Gomez https://github.com/GuillaumeGomez/systemd-manager/

Contributing

Contact me on my GitHub if you want to contribute to this project.

Project Roadmap

For now new features are planned to be added, such as:

  • Non-blocking calls (in progress)
  • Always administrator mode
  • Improve UX (continuously)

Installation Instructions

From your computer

  • Download and install rust https://www.rust-lang.org/tools/install
  • Install the build essentials
    • Install GTK 4 and the build essentials. how-to
    • Install libadwaita how-to
    • Install systemd development library libsystemd-dev
  • Compile and install cargo install sysd-manager
  • Run sysd-manager

Install on RHEL, Fedora, and CentOS based distributions

Important not up to date for a while, since Fedora rust librairies needed to build the project aren't updated. You can install the application from COPR

Add the repo

First, you need to have dnf-plugins-core installed

sudo dnf install dnf-plugins-core

Then you can enable the repo with the following command

sudo dnf copr enable plrigaux/sysd-manager

Install with dnf

Then you can simply install sysd-manager with the following command

sudo dnf install sysd-manager

Generate RPM for COPR

1 be in the mock group Add your user name to the mock group

sudo usermod -a -G mock <my user name>

Generate a RPM locally

You can generate your rpm locally with the help of the crate cargo-generate-rpm.

Install

cargo install cargo-generate-rpm

Usage

cargo build --release
strip -s target/release/sysd-manager
cargo generate-rpm

Install with dnf

Then you can install sysd-manager with the following command

Don't forget to ajust the the rpm file path

sudo dnf localinstall target/generate-rpm/sysd-manager[version-release-arch].rpm

Setup

cargo install cargo-generate-rpm

Usage

Run the following script.

sh ./create_rpm

It will create a rpm file in the target/generate-rpm subdirectory.

Flatpak

SysD Manager can be build as a flatpak, but the flatpak version has limitations that can be overcome.

The limitation are :

  • can't display journal
  • Can't save the unit file

The application discloses how to overcome those limitations.

Install the builder

flatpak install org.flatpak.Builder

Build the flatpak

./goflatub build

Run the flatpak

To run the compiled flatpak execute the following command

./goflatub run

To access all program's functionnalities, you need the to have program flatpak-spawn install on your system.

Possible issue

No remote refs found for ‘flathub’

flatpak remote-add --user --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo

APT

Later waiting for a contributor or when I will reinstall e Debian like distro

Testing

If you want to test Sysd Manager without risking to shutdown impotant services, you can do it with tiny_daemon. tiny_daemon is a service provided with the project as a simple web server that you can safely play with.

To install tiny_daemon, in the project directory, just run this python script.

python install_tiny 

or if install_tiny is executable (i.e. chmod +x install_tiny)

./install_tiny 

License: GPL v3

Dependencies

~30–43MB
~819K SLoC