When should the option RemainAfterExit needs to be set true when creating new systemd services?

后端 未结 3 1089
萌比男神i
萌比男神i 2021-01-03 20:19

I am trying to write a few services. Some of them have \'type\' option set to oneshot. But i am still confused when the option \'RemainAfterExit\' needs to be set true. (not

相关标签:
3条回答
  • 2021-01-03 20:57

    The flag is useful for your own bookkeeping and accounting. If it's useful to you to consider the service active after's finished, you can set the flag.

    0 讨论(0)
  • 2021-01-03 21:03

    From Systemd page below is the description of RemainAfterExit

    RemainAfterExit= Takes a boolean value that specifies whether the service shall be considered active even when all its processes exited. Defaults to no.

    This simply means that if all your processes started from service exits, when you query the status of the service, its still says active if this flag is set to true. If set to false, then service status is inactive.

    This is particularly useful when you are adding dependency on services during bootup. wherein the service status is important to start dependent services.

    0 讨论(0)
  • 2021-01-03 21:04

    Use RemainAfterExit=yes for services, which somehow change state of the system. When you want that state reverted, you just stop the service. Then you can start it again, but not without first stopping it. An example would be service which creates a flag in filesystem to be used by some other application. On start, it create the flag file, then exists, but the service is kept as active by systemd. Then you can stop it and it will remove the flag file.

    Use RemainAfterExit=no for services, which do some action, but do not change the state of the system. An example would be a service to cleanup /tmp. You start it, it will do its work and then be inactive (no need to stop it). And you can start it again anytime and will again to its work (cleanup).

    0 讨论(0)
提交回复
热议问题