diff options
author | Arthur Shau <arthurshau@meta.com> | 2024-03-14 20:43:13 +0100 |
---|---|---|
committer | Matteo Croce <teknoraver@meta.com> | 2024-10-11 22:54:16 +0200 |
commit | cc0ab8c81031fae2b28e66f52972473875931278 (patch) | |
tree | ef6884742e8746b175d7dd87e40cc74e24d27947 /man/org.freedesktop.systemd1.xml | |
parent | Merge pull request #34700 from yuwata/network-conf-parser (diff) | |
download | systemd-cc0ab8c81031fae2b28e66f52972473875931278.tar.xz systemd-cc0ab8c81031fae2b28e66f52972473875931278.zip |
timer: introduce DeferReactivation setting
By default, in instances where timers are running on a realtime schedule,
if a service takes longer to run than the interval of a timer, the
service will immediately start again when the previous invocation finishes.
This is caused by the fact that the next elapse is calculated based on
the last trigger time, which, combined with the fact that the interval
is shorter than the runtime of the service, causes that elapse to be in
the past, which in turn means the timer will trigger as soon as the
service finishes running.
This behavior can be changed by enabling the new DeferReactivation setting,
which will cause the next calendar elapse to be calculated based on when
the trigger unit enters inactivity, rather than the last trigger time.
Thus, if a timer is on an realtime interval, the trigger will always
adhere to that specified interval.
E.g. if you have a timer that runs on a minutely interval, the setting
guarantees that triggers will happen at *:*:00 times, whereas by default
this may skew depending on how long the service runs.
Co-authored-by: Matteo Croce <teknoraver@meta.com>
Diffstat (limited to 'man/org.freedesktop.systemd1.xml')
-rw-r--r-- | man/org.freedesktop.systemd1.xml | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/man/org.freedesktop.systemd1.xml b/man/org.freedesktop.systemd1.xml index ccc3e25fbc..1e34ddbc85 100644 --- a/man/org.freedesktop.systemd1.xml +++ b/man/org.freedesktop.systemd1.xml @@ -8804,6 +8804,8 @@ node /org/freedesktop/systemd1/unit/systemd_2dtmpfiles_2dclean_2etimer { readonly b WakeSystem = ...; @org.freedesktop.DBus.Property.EmitsChangedSignal("const") readonly b RemainAfterElapse = ...; + @org.freedesktop.DBus.Property.EmitsChangedSignal("const") + readonly b DeferReactivation = ...; }; interface org.freedesktop.DBus.Peer { ... }; interface org.freedesktop.DBus.Introspectable { ... }; @@ -8832,6 +8834,8 @@ node /org/freedesktop/systemd1/unit/systemd_2dtmpfiles_2dclean_2etimer { <!--property RemainAfterElapse is not documented!--> + <!--property DeferReactivation is not documented!--> + <!--Autogenerated cross-references for systemd.directives, do not edit--> <variablelist class="dbus-interface" generated="True" extra-ref="org.freedesktop.systemd1.Unit"/> @@ -8874,6 +8878,8 @@ node /org/freedesktop/systemd1/unit/systemd_2dtmpfiles_2dclean_2etimer { <variablelist class="dbus-property" generated="True" extra-ref="RemainAfterElapse"/> + <variablelist class="dbus-property" generated="True" extra-ref="DeferReactivation"/> + <!--End of Autogenerated section--> <refsect2> @@ -12386,5 +12392,9 @@ $ gdbus introspect --system --dest org.freedesktop.systemd1 \ <title>Job Objects</title> <para><varname>ActivationDetails</varname> was added in version 252.</para> </refsect2> + <refsect2> + <title>Timer Objects</title> + <para><varname>DeferReactivation</varname> was added in version 257.</para> + </refsect2> </refsect1> </refentry> |