Difference between revisions of "Rcorder"
(Created page with "{{welcome}} {{Navbar OpenRC}} ==Introduction== Category:Sysutils") |
(→rc Script Ordering) |
||
(8 intermediate revisions by the same user not shown) | |||
Line 4: | Line 4: | ||
==Introduction== | ==Introduction== | ||
+ | The [https://www.freebsd.org/cgi/man.cgi?query=rcorder&apropos=0&sektion=0&manpath=FreeBSD+12.1-RELEASE+and+Ports&arch=default&format=html ''rcorder''] utility is designed to print out a dependency ordering of a set of interdependent files. Typically it is used to find an execution sequence for a set of shell scripts in which certain files must be executed before others. | ||
+ | Each file passed to ''rcorder'' must be annotated with special lines (which look like comments to the shell) which indicate the dependencies the files have upon certain points in the sequence, known as "conditions", | ||
+ | and which indicate, for each file, which "conditions" may be expected to be filled by that file. | ||
+ | |||
+ | ==rc Script Ordering== | ||
+ | |||
+ | Each rc script identifies what resources it needs before it can start. The [https://www.freebsd.org/cgi/man.cgi?query=rcorder&apropos=0&sektion=0&manpath=FreeBSD+12.1-RELEASE+and+Ports&arch=default&format=html rcorder(8)] sorts all the scripts in '''/etc/[[Rc.d|rc.d]]''' and '''/usr/[[Local/etc/rc.d|local/etc/rc.d]]''' in to the order used at system boot. If your rc scripts have any ordering errors, those errors appear at the beginning of your [https://www.freebsd.org/cgi/man.cgi?query=rcorder&apropos=0&sektion=0&manpath=FreeBSD+12.1-RELEASE+and+Ports&arch=default&format=html rcorder(8)] output. | ||
+ | |||
+ | ==A Example rc Script== | ||
+ | |||
+ | |||
+ | {|class="wikitable" style="width:96.5%;background:#FFFFFF; border:2px solid #008000;text-align:left;padding: 10px" | ||
+ | |- | ||
+ | ! scope="col" style="width: 100px;"|'''Lines''' | ||
+ | ! scope="col" style="width: 350px;"|'''Description''' | ||
+ | |- | ||
+ | |#!/bin/sh||Indicates the interpreter /bin/sh | ||
+ | |- | ||
+ | |#|| | ||
+ | |- | ||
+ | |# $FreeBSD$|| | ||
+ | |- | ||
+ | |#|| | ||
+ | |- | ||
+ | !colspan="2"| | ||
+ | |- | ||
+ | |# PROVIDE: timed||PROVIDE tells the [https://www.freebsd.org/cgi/man.cgi?query=rcorder&apropos=0&sektion=0&manpath=FreeBSD+12.1-RELEASE+and+Ports&arch=default&format=html rcorder(8)] the name of the script: ''timed''. | ||
+ | |- | ||
+ | |# REQUIRE: DAEMON||REQUIRE says which other scripts must run any time before the script ''timed''. | ||
+ | |- | ||
+ | |# BEFORE: LOGIN||BEFORE says: ''timed'' must run before the LOGIN script. | ||
+ | |- | ||
+ | |# KEYWORD: nojail shutdown||The KEYWORD command lets select only special sturtup scripts. The [https://www.freebsd.org/cgi/man.cgi?query=timed&apropos=0&sektion=0&manpath=FreeBSD+12.1-RELEASE+and+Ports&arch=default&format=html ''timed(8)''] script ''nojail'' and ''shutdown''. Jail don't run this script. This script runs at system shutdown. | ||
+ | |- | ||
+ | !colspan="2"| | ||
+ | |- | ||
+ | |. /etc/rc.subr||The ''/etc/rc.subr'' functions used by various rc scripts | ||
+ | |- | ||
+ | !colspan="2"| | ||
+ | |- | ||
+ | |name="timed"||Set the variable name. | ||
+ | |- | ||
+ | |desc="Time server daemon"||description field, purpose of the script | ||
+ | |- | ||
+ | |rcvar="timed_enable"||lists the rc.conf variable that toggles this script | ||
+ | |- | ||
+ | |command="/usr/sbin/${name}"||The command identifies which command this script should run after all. | ||
+ | |- | ||
+ | !colspan="2"| | ||
+ | |- | ||
+ | |load_rc_config $name||load the the configuration for the service from '''/etc/[[Rc.conf|rc.conf]]''' | ||
+ | |- | ||
+ | |run_rc_command "$1"||run the command | ||
+ | |} | ||
[[Category:Sysutils]] | [[Category:Sysutils]] |
Latest revision as of 05:23, 25 March 2020
Welcome to Rcorder. |
OpenRC | ||
---|---|---|
Scripts | ||
/etc/rc rc - shell |
/etc/rc.devd The generic hook into OpenRC. |
/sbin/rcorder Ordering rc-scripts |
/etc/init.d Scripts to run OpenRC |
/usr/local/etc/init.d Scripts to run OpenRC |
|
/etc/rc.d Scripts automatically executed at boot and shutdown |
/usr/local/etc/rc.d Special scripts |
|
Configuration | ||
/etc/devd.conf Configuration file for devd(8) |
/etc/conf.d Initscript Configuration Files |
/etc/rc.conf.d Smaller configuration files |
/etc/defaults/rc.conf Specifies the default settings for all the available options. |
/etc/rc.conf The global OpenRC configuration file |
/etc/rc.conf.ghostbsd GhostBSD specific configurations |
Tools/Helper | ||
/usr/sbin/sysrc Safely edit system rc files |
/bin/rc-status Shows which services are running |
/sbin/rc-update Add or delete services |
/sbin/rc-service Locate and run an OpenRC service |
||
Back to the System |
Introduction[edit]
The rcorder utility is designed to print out a dependency ordering of a set of interdependent files. Typically it is used to find an execution sequence for a set of shell scripts in which certain files must be executed before others.
Each file passed to rcorder must be annotated with special lines (which look like comments to the shell) which indicate the dependencies the files have upon certain points in the sequence, known as "conditions", and which indicate, for each file, which "conditions" may be expected to be filled by that file.
rc Script Ordering[edit]
Each rc script identifies what resources it needs before it can start. The rcorder(8) sorts all the scripts in /etc/rc.d and /usr/local/etc/rc.d in to the order used at system boot. If your rc scripts have any ordering errors, those errors appear at the beginning of your rcorder(8) output.
A Example rc Script[edit]
Lines | Description |
---|---|
#!/bin/sh | Indicates the interpreter /bin/sh |
# | |
# $FreeBSD$ | |
# | |
# PROVIDE: timed | PROVIDE tells the rcorder(8) the name of the script: timed. |
# REQUIRE: DAEMON | REQUIRE says which other scripts must run any time before the script timed. |
# BEFORE: LOGIN | BEFORE says: timed must run before the LOGIN script. |
# KEYWORD: nojail shutdown | The KEYWORD command lets select only special sturtup scripts. The timed(8) script nojail and shutdown. Jail don't run this script. This script runs at system shutdown. |
. /etc/rc.subr | The /etc/rc.subr functions used by various rc scripts |
name="timed" | Set the variable name. |
desc="Time server daemon" | description field, purpose of the script |
rcvar="timed_enable" | lists the rc.conf variable that toggles this script |
command="/usr/sbin/${name}" | The command identifies which command this script should run after all. |
load_rc_config $name | load the the configuration for the service from /etc/rc.conf |
run_rc_command "$1" | run the command |