Automate network configurations with dispatcher scripts
Debugging
Since NetworkManager runs in the background except for the configuration work, you cannot easily check your own dispatcher scripts for errors. If something goes wrong, don't expect a window with helpful error messages. If there is a bug in the script, simply nothing happens. To find programming errors, check out the system logs.
On the one hand, nmcli monitor
lets you trace what NetworkManager is doing in real time. You can see the network device names and what actions are currently running. To view the NetworkManager logs, you need to read the system journal with journalctl
. The following command:
journalctl -f -u NetworkManager
lets you have a look at the log in real time and filter the output from NetworkManager (Listing 9).
Listing 9
journalctl
$ journalctl -f -u NetworkManager [...] May 22 23:21:45 ontario NetworkManager[485]: <warn> [1590182505.2987] dispatcher: (44) /etc/NetworkManager/dispatcher.d/30-mount-diskstation failed (failed): Script '/etc/NetworkManager/dispatcher.d/30-mount-diskstation' exited with error status 2. $ nmcli monitor enp0s31f6: Connection "LAN1" is used enp0s31f6: is connected (being prepared) NetworkManager is now in the state "being connected [...] NetworkManager is now in "connected" state Connection state is now "complete
These commands give you a general overview of NetworkManager's actions. However, in order to search for an error, it is recommended that you send content to the systemd log yourself at critical points using logger
. For an example, as shown in Listing 10, you can use the $0
(script name), $1
(network device), and $2
(action) variables also used by NetworkManager for dispatching, as well as the environment variables provided by the dispatcher function, such as $CONNECTION_UUUID
or $IP4_DOMAINS
(Listing 11).
Listing 10
Logging
#!/bin/bash logger "Logger: Run script $0." if [ "$2" = "up" ]; then logger "LOGGER: network device: $1, action: $2" logger "LOGGER: Environment: CONNECTION_UUUID=$CONNECTION_UUID, IP4_DOMAINS=$IP4_DOMAINS" fi
Listing 11
grepping the Log
$ journalctl -f | grep LOGGER [...] May 22 23:36:47 root [16135]: LOGGER: Run script /etc/NetworkManager/dispatcher.d/30-mount-diskstation May 22 23:36:47 root [16136]: LOGGER: network device: enp0s31f6, action: up May 22 23:50:31 oroot[18811]: LOGGER: Environment: CONNECTION_UUUID=2911db45-3eff-3b74-9c87-4c36e0290693, IP4_DOMAINS=fritz.box
Conclusion
A meaningful dispatcher script will not automatically write itself. It takes some time to get everything working as desired. But once you work through all the details, you can get a dispatcher script to do almost anything you can do on the system at the file level. The biggest difficulty is extracting log output or viewing the environment variables populated during dispatching. But if you know the tricks, you can quickly overcome these hurdles.
Infos
« Previous 1 2
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Direct Download
Read full article as PDF:
Price $2.95
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
News
-
An All-Snap Version of Ubuntu is In The Works
Along with the standard deb version of the open-source operating system, Canonical will release an-all snap version.
-
Mageia 9 Beta 2 Ready for Testing
The latest beta of the popular Mageia distribution now includes the latest kernel and plenty of updated applications.
-
KDE Plasma 6 Looks to Bring Basic HDR Support
The KWin piece of KDE Plasma now has HDR support and color management geared for the 6.0 release.
-
Bodhi Linux 7.0 Beta Ready for Testing
The latest iteration of the Bohdi Linux distribution is now available for those who want to experience what's in store and for testing purposes.
-
Changes Coming to Ubuntu PPA Usage
The way you manage Personal Package Archives will be changing with the release of Ubuntu 23.10.
-
AlmaLinux 9.2 Now Available for Download
AlmaLinux has been released and provides a free alternative to upstream Red Hat Enterprise Linux.
-
An Immutable Version of Fedora Is Under Consideration
For anyone who's a fan of using immutable versions of Linux, the Fedora team is currently considering adding a new spin called Fedora Onyx.
-
New Release of Br OS Includes ChatGPT Integration
Br OS 23.04 is now available and is geared specifically toward web content creation.
-
Command-Line Only Peropesis 2.1 Available Now
The latest iteration of Peropesis has been released with plenty of updates and introduces new software development tools.
-
TUXEDO Computers Announces InfinityBook Pro 14
With the new generation of their popular InfinityBook Pro 14, TUXEDO upgrades its ultra-mobile, powerful business laptop with some impressive specs.