The s6-rc-set-change program
s6-rc-set-change modifies a set by changing the rx of some services.
Interface
s6-rc-set-change [ -v verbosity ] [ -r repo ] [ -E | -e ] [ -f | -I fail|pull|warn ] [ -n ] set newrx services...
- s6-rc-set-change operates on set set in repository repo.
- It attempts to move all the services listed in services... into rx newrx.
- It exits 0.
Options
- -v verbosity, --verbosity=verbosity
- Be more or less verbose. The default is 1, which means that error messages and warnings will be written to stderr. 0 means that only error messages will be written, and 2 or more adds informational messages.
- -r repo, --repository=repo
- Use the repository in repo, which must exist. Default is /var/lib/s6-rc/repository.
- -E, --no-force-essential
- If a service needs to be moved to/from the always rx, fail and report an error. This is the default. Services marked as always are normally defined in the stores with flag-essential, and inconsistencies between essential services should be resolved in the stores.
- -e, --force-essential
- Move services to/from the always rx if they need to be. This option should only be used temporarily until the store inconsistency is fixed. Be aware that moving a service from always to usable or masked may result in an unbootable set.
- -f, --ignore-dependencies
- Change services... to newrx, but do not change any other services, even if the dependency graph would normally mandate it. This may result in an inconsistent set that you cannot commit.
- fail: print an error message and exit 1.
- warn: print a warning message and proceed. This is the default.
- pull: print a warning message and pull the dependencies of services... into newrx. (Or the reverse dependencies, if you're trying to disable or mask services.
Exit codes
- 0
- Success.
- 1
- -I fail was given and dependencies prevented services... from being changed to newrx.
- 3
- A service in services... was not found in the reference database.
- 4
- Invalid or corrupted reference database.
- 100
- Incorrect usage.
- 102
- Inconsistent repository.
- 111
- System call failed.
Notes
- s6-rc-set-change is the bread and butter of repo operations. It is how users can tailor the set of services they want to be enabled at boot time.
- Once a change has been effected, and the command says that the set is consistent, it can be committed.
- If you are masking or unmasking services, and you see it pulling services that are not dependencies of the service you're unmasking or are not depending on the service you're masking, it is because these services are part of the same pipeline. If you mask a part of a pipeline, the whole pipeline needs to be masked.
