Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

How to create systemd unit that depends on a website being up?

+1
−0

I'm going to write some systemd services. All of these can only be run if a certain website is up. I thought I could create a ~/.config/systemd/user/website.service this:

[Unit]
Description=Confirm that example is up
Wants=network-online.target
After=network-online.target nss-lookup.target

[Service]
ExecStart=curl --head example.com

And then I can make my actual units have Requires=website.service.

When I run systemctl --user start website, it just exits. When I check systemctl --user status website I see the header in the logs. But the status just says "inactive", not success or fail (based on exit code of fail).

When I tell systemd to run my other units, it should first run website.service, and only if it succeeds should the target units run. Otherwise they should fail. How do I accomplish this?

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.
Why should this post be closed?

2 comment threads

this sounds related to the type of systemd service/unit. Check the man pages for `systemd.service` or... (1 comment)
And furthermore, systemd should be destroyed. :) (1 comment)

1 answer

+0
−0

To make your example work, you should add Type=oneshot and RemainAfterExit=true to the [Service] section. This way the unit won't be considered active until the curl has actually succeeded, and either won't go inactive afterwards.

However, this is somewhat unorthodox way of going about it. One would expect website.service to really manage the service process, and not be just a proxy for it (using curl in this case).

Instead you could just add the unit actually managing the server process as a dependency to your other units. E.g. on Ubuntu your website might be running on Apache:

[Unit]
Description=A thing requiring the website
Requisite=apache2.service
After=apache2.service

[Service]
...

Requisite makes starting the unit simply fail if Apache isn't running. It won't try to start it (as unwittingly starting web services can lead to security issues).

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.

1 comment thread

The website isn't on the same host. It's some other website on the internet. (1 comment)

Sign up to answer this question »