Today’s systemd reads its initialization configuration for each daemon from a collection of unit files, which are often just called units. With path units, you can monitor files and directories for certain events. If a specified event occurs, a service unit is executed, and it usually carries the same name as the path unit. I will show how this works with a simple example.
Let’s assume we would like to monitor a file. Whenever the file is closed after a write, a specific script should start.
The path unit: example.path
In the directory /etc/systemd/system/ we create the file example.path with the following content:
[Unit]
Description=Monitor the file for changes
[Path]
PathChanged=/home/john/testfile
Unit=example.service
[Install]
WantedBy=multi-user.target
In the [Path] section, PathChanged= specifies the absolute path to the file to be monitored, while Unit= indicates which service unit to execute if the file changes. This unit (example.path) should be started when the system is in multi-user mode.
Next, we create the corresponding service unit example.service in /etc/systemd/system/.
The service unit: example.service
If the file testfile changes (meaning that it is both written to and closed), the following service unit will be called to execute the specified script:
[Unit]
Description=Executes script when a file has changed.
[Service]
Type=simple
ExecStart=/home/john/script.sh
[Install]
WantedBy=multi-user.target
In this example, the file script.sh contains only the following code:
#!/bin/bash
echo "file changed" >/home/john/output.txt
To test the path unit, both of these new units must be activated, so run:
$ sudo systemctl enable example.{path,service}
$ sudo systemctl start example.path
If you now rewrite—or write to—the file testfile, the corresponding service unit is executed, and the file output.txt is created in user john's home directory.
The following incomplete and non-exhaustive list gives some examples where path units could make your Sysadmin Day a bit easier:
- Start event-driven data processing.
- Monitor files under
/etc, and send a notification when changes occur. - Monitor the
importfolder for new files, and start processing.
Things to be aware of
During my tests with path units, I noticed that not all events are caught under certain circumstances. For example, set up a path unit to monitor a path for changes, and then run the following command:
$ touch /path/file && rm /path/file
I would expect the service unit to be executed twice, here: the first time for the touch command, and the second time for the rm command. I filed a Bugzilla report to see if this issue is due to design, or a glitch that can be fixed.
Sources and related links
If you want to learn more about systemd units, including path and service units, take a look at the following man pages:
- systemd.unit (5)
- systemd.path (5)
- systemd.service (5)
Also, if you are interested in the results of my bug report, you can follow it here:
저자 소개
Jörg has been a Sysadmin for over ten years now. His fields of operation include Virtualization (VMware), Linux System Administration and Automation (RHEL), Firewalling (Forcepoint), and Loadbalancing (F5). He is a member of the Red Hat Accelerators Community and author of his personal blog at https://www.my-it-brain.de.
유사한 검색 결과
More than meets the eye: Behind the scenes of Red Hat Enterprise Linux 10 (Part 4)
Why should your organization standardize on Red Hat Enterprise Linux today?
The Overlooked Operating System | Compiler: Stack/Unstuck
Linux, Shadowman, And Open Source Spirit | Compiler
채널별 검색
오토메이션
기술, 팀, 인프라를 위한 IT 자동화 최신 동향
인공지능
고객이 어디서나 AI 워크로드를 실행할 수 있도록 지원하는 플랫폼 업데이트
오픈 하이브리드 클라우드
하이브리드 클라우드로 더욱 유연한 미래를 구축하는 방법을 알아보세요
보안
환경과 기술 전반에 걸쳐 리스크를 감소하는 방법에 대한 최신 정보
엣지 컴퓨팅
엣지에서의 운영을 단순화하는 플랫폼 업데이트
인프라
세계적으로 인정받은 기업용 Linux 플랫폼에 대한 최신 정보
애플리케이션
복잡한 애플리케이션에 대한 솔루션 더 보기
가상화
온프레미스와 클라우드 환경에서 워크로드를 유연하게 운영하기 위한 엔터프라이즈 가상화의 미래