diff --git a/doc/66-all.html b/doc/66-all.html new file mode 100644 index 0000000000000000000000000000000000000000..369808b8d41d7728f65c6fcb79447079f8b0db16 --- /dev/null +++ b/doc/66-all.html @@ -0,0 +1,74 @@ +<html> + <head> + <meta name="viewport" content="width=device-width, initial-scale=1.0" /> + <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> + <meta http-equiv="Content-Language" content="en" /> + <title>The 66 Suite: 66-all</title> + <meta name="Description" content="Detailed documentation for the 66-all command which is part of the 66 software suite" /> + <meta name="Keywords" content="66 command 66-all service supervision supervise handles database service tree" /> + <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> --> + </head> +<body> + +<p> +<a href="index.html">66</a><br /> +<a href="//obarun.org/">www.obarun.org</a> +</p> + +<h1>66-all</h1> + + <p> + This command handles all <em>service</em> for all <em>tree</em> define for the current user of the proccess. + </p> + +<h2> Interface </h2> + <pre> + 66-all [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T timeout ] <em>up/down</em> + </pre> + + <p> + This tool expects to find an enabled <em>tree(s)</em>—see <a href="66-tree.html"><tt>66-tree -E</tt></a> option, or a specific one given by <tt>-t</tt> option of the current user of the process + and an already running <em>scandir</em>. + This tool is a safe wrapper build around <tt><a href="66-start.html">66-start</a></tt> and <tt><a href="66-stop.html">66-stop</a></tt> tools. + </p> + + +<h2> Options </h2> + + <ul> + <li> <tt>-h </tt> : prints this help. </li> + + <li> + <tt>-v <em>verbosity</em> </tt>: increases/decreases + the verbosity of the command. <tt>1(Default)</tt>: Only print + error messages. <tt>2</tt>: Also print warning messages. + <tt>3</tt>: Also print debugging messages. + </li> + + <li> + <tt>-l <em>live</em></tt> : changes the supervision directory of <em>service</em> to <em>live</em>. By default this will be <tt>/run/66</tt>. The default can + also be changed at compile time by passing the <tt>--livedir=<em>live</em></tt> + option to <tt>./configure</tt>. An existing absolute path is expected and + should be within a writable filesystem - likely a RAM filesystem—see <tt><a href="66-scandir.html">66-scandir</a></tt>. + </li> + <li> + <tt>-t <em>tree</em></tt> : only handles <em>service(s)</em> for <em>tree</em>. + </li> + + <li> + <tt>-T <em>timeout</em></tt></tt> : specifies a general timeout (in milliseconds) + passed to <tt>66-start</tt> or <tt>66-stop</tt> program. + By default, the timeout is 0, which means infinite. + </li> + <li> + <tt>up </tt> : sends a up signal to the all <em>service</em> of all <em>tree</em>. + </li> + <li> + <tt>down </tt> : sends a down signal to the all <em>service</em> of all <em>tree</em>. + </li> + </ul> + +<h2> Initialization phase </h2> +<p>In case of <tt>up</tt> signal, <tt>66-all</tt> will launch <tt><a href="66-init.html">66-init</a></tt> program to initiate <em>service(s)</em> of the <em>tree(s)</em>.</p> +</body> +</html> diff --git a/doc/66-dbctl.html b/doc/66-dbctl.html new file mode 100644 index 0000000000000000000000000000000000000000..ed01735e90bcb80c47709d51f565e29de1639da8 --- /dev/null +++ b/doc/66-dbctl.html @@ -0,0 +1,76 @@ +<html> + <head> + <meta name="viewport" content="width=device-width, initial-scale=1.0" /> + <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> + <meta http-equiv="Content-Language" content="en" /> + <title>The 66 Suite: 66-dbctl</title> + <meta name="Description" content="Detailed documentation for the 66-dbctl command which is part of the 66 software suite" /> + <meta name="Keywords" content="66 command 66-dbctl service supervision supervise handles database service" /> + <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> --> + </head> +<body> + +<p> +<a href="index.html">66</a><br /> +<a href="//obarun.org/">www.obarun.org</a> +</p> + +<h1>66-dbctl</h1> + + <p> + This command is used to control an already supervised <em>services</em> in <em>live</em> defined in <em>tree</em>. + </p> + +<h2> Interface </h2> + <pre> + 66-dbctl [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -u up ] [ -d down ] <em>service(s)</em> + </pre> + + <p> + This tool expects to find an already supervised <em>service</em> in <em>live</em> defined in the given <em>tree</em> and an already running <em>scandir</em>. + This tool only deal with <em>'bundle'</em>, <em>'longrun'</em>, <em>'oneshot'</em> service—see <a href="66-svctl.html"><tt>66-svctl</tt></a> for <em>'classic'</em> services. + </p> + <p>Multiple <em>services</em> can be handled by seperating their names with a space. <tt>66-dbctl</tt> gathers the service(s) passed as argument in a list called <em>selection</em>.</p> + +<h2> Options </h2> + + <ul> + <li> <tt>-h </tt> : prints this help. </li> + + <li> + <tt>-v <em>verbosity</em> </tt>: increases/decreases + the verbosity of the command. <tt>1(Default)</tt>: Only print + error messages. <tt>2</tt>: Also print warning messages. + <tt>3</tt>: Also print debugging messages. + </li> + + <li> + <tt>-l <em>live</em></tt> : changes the supervision directory of <em>service</em> to <em>live</em>. By default this will be <tt>/run/66</tt>. The default can + also be changed at compile time by passing the <tt>--livedir=<em>live</em></tt> + option to <tt>./configure</tt>. An existing absolute path is expected and + should be within a writable filesystem - likely a RAM filesystem—see <tt><a href="66-scandir.html">66-scandir</a></tt>. + </li> + <li> + <tt>-t <em>tree</em></tt> : handles the <em>selection</em> from + the given <em>tree</em>. This option is mandatory + except if a tree was marked as 'current'—see <a href="66-tree.html"><tt>66-tree</tt></a>. + </li> + + <li> + <tt>-T <em>timeout</em></tt></tt> : specifies a general timeout (in milliseconds) + after which <tt>66-dbctl</tt> will exit 111 with an error message if the <em>selection</em> still hasn't reached the desired state for each <em>service</em>. + By default, the timeout is 0, which means that <tt>66-dbctl</tt> will block indefinitely. + </li> + <li> + <tt>-u </tt> : sends a up signal to the <em>service</em>. + </li> + <li> + <tt>-d </tt> : sends a down signal to the <em>service</em>. + </li> + </ul> + +<h2> Note </h2> +<p>This tool is a safe wrapper built around <tt><a href="https://skarnet.org/software/s6-rc/s6-rc.html">s6-rc</a></tt>. It only handles <tt>66</tt> ecosystem files before sending the <em>selection</em> to +<tt>s6-rc</tt> program.</p> +</body> +</html> diff --git a/doc/66-disable.html b/doc/66-disable.html index c53bf0a6bca1d7a8cc84b189ec00853f2f6fa843..6020a2621388bc6b6230a5a860b8524fb86f64a1 100644 --- a/doc/66-disable.html +++ b/doc/66-disable.html @@ -23,7 +23,7 @@ <h2> Interface </h2> <pre> - 66-disable [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -S stop ] <em>service(s)</em>" + 66-disable [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -S stop ] <em>service(s)</em> </pre> <p> diff --git a/doc/66-enable.html b/doc/66-enable.html index 472aeaa652d10f70251be2d9d5d5b2b2d4656b8d..51af094b0eaafcbf8c7dba519d28ed0239bfe653 100644 --- a/doc/66-enable.html +++ b/doc/66-enable.html @@ -23,7 +23,7 @@ <h2> Interface </h2> <pre> - 66-enable [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -f force ] [ -S start ] <em>service(s)</em>" + 66-enable [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -f force ] [ -S start ] <em>service(s)</em> </pre> <p> diff --git a/doc/66-start.html b/doc/66-start.html index 65f2044f9e4b3404fcac92833b7d94e7092e1520..81cba6277181f532936704035a1bc3c7c93a61ed 100644 --- a/doc/66-start.html +++ b/doc/66-start.html @@ -23,7 +23,7 @@ <h2> Interface </h2> <pre> - 66-start [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -r reload ] <em>service(s)</em>" + 66-start [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -r reload ] <em>service(s)</em> </pre> <p> diff --git a/doc/66-stop.html b/doc/66-stop.html index a508093d3765e144c1995f78846c51f368e07d08..d6f9acc3f6b1ef82639a9b1c203fd8550ad199dc 100644 --- a/doc/66-stop.html +++ b/doc/66-stop.html @@ -23,7 +23,7 @@ <h2> Interface </h2> <pre> - 66-stop [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -u unsupervise ] <em>service(s)</em>" + 66-stop [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -u unsupervise ] <em>service(s)</em> </pre> <p> diff --git a/doc/66-svctl.html b/doc/66-svctl.html new file mode 100644 index 0000000000000000000000000000000000000000..b03687450021a487e006a25df5cbf545a8040bc7 --- /dev/null +++ b/doc/66-svctl.html @@ -0,0 +1,95 @@ +<html> + <head> + <meta name="viewport" content="width=device-width, initial-scale=1.0" /> + <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> + <meta http-equiv="Content-Language" content="en" /> + <title>The 66 Suite: 66-svctl</title> + <meta name="Description" content="Detailed documentation for the 66-svctl command which is part of the 66 software suite" /> + <meta name="Keywords" content="66 command 66-svctl service supervision supervise handles service" /> + <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> --> + </head> +<body> + +<p> +<a href="index.html">66</a><br /> +<a href="//obarun.org/">www.obarun.org</a> +</p> + +<h1>66-svctl</h1> + + <p> + This command is used to control an already supervised <em>services</em> in <em>live</em> defined in <em>tree</em>. + </p> + +<h2> Interface </h2> + <pre> + 66-svctl [ -h help ] [ -v <em>verbosity</em> ] [ -l <em>live</em> ] [ -t <em>tree</em> ] [ -T <em>timeout</em> ] [ -S <em>service timeout</em> ] [ -n <em>death</em> ] [ -u|U up ] [ -d|D down ] <em>service(s)</em> + </pre> + + <p> + This tool expects to find an already supervised <em>service</em> in <em>live</em> defined in the given <em>tree</em> and an already running <em>scandir</em>. + This tool only deal with <em>'classic'</em> service—see <a href="66-dbctl.html"><tt>66-dbctl</tt></a> for other kind of services. + </p> + <p>Multiple <em>services</em> can be handled by seperating their names with a space. <tt>66-svctl</tt> gathers the service(s) passed as argument in a list called <em>selection</em>.</p> + +<h2> Options </h2> + + <ul> + <li> <tt>-h </tt> : prints this help. </li> + + <li> + <tt>-v <em>verbosity</em> </tt>: increases/decreases + the verbosity of the command. <tt>1(Default)</tt>: Only print + error messages. <tt>2</tt>: Also print warning messages. + <tt>3</tt>: Also print debugging messages. + </li> + + <li> + <tt>-l <em>live</em></tt> : changes the supervision directory of <em>service</em> to <em>live</em>. By default this will be <tt>/run/66</tt>. The default can + also be changed at compile time by passing the <tt>--livedir=<em>live</em></tt> + option to <tt>./configure</tt>. An existing absolute path is expected and + should be within a writable filesystem - likely a RAM filesystem—see <tt><a href="66-scandir.html">66-scandir</a></tt>. + </li> + <li> + <tt>-t <em>tree</em></tt> : handles the <em>service</em> from + the given <em>tree</em>. This option is mandatory + except if a tree was marked as 'current'—see <a href="66-tree.html"><tt>66-tree</tt></a>. + </li> + + <li> + <tt>-T <em>timeout</em></tt></tt> : specifies a general timeout (in milliseconds) + after which <tt>66-svctl</tt> will exit 111 with an error message if the <em>selection</em> still hasn't reached the desired state for each <em>service</em>. + By default, the timeout is 0, which means that <tt>66-svctl</tt> will block indefinitely. + </li> + + <li> + <tt>-S <em>service timeout</em></tt> : specifies a timeout (in milliseconds) + after which <tt>66-svctl</tt> will exit 111 with an error message if the <em>services</em> still hasn't reached the desired state. + This option has <strong>no effects</strong> if a <em>timeout-up</em> (for <em>up</em> signal) or <em>timeout-down</em> (for <em>down</em> signal) was defined + for the given service at the parsing time—see <tt><a href="66-frontend.html">frontend</a></tt>. In such case priority is given to those files. + If the option is not given and the <em>timeout-up,timeout-down</em> files doesn't exist, 1000 is pick by default. + </li> + + <li> + <tt>-n <em>death</em></tt> : specifies the maximum number of service death events that the supervisor will keep track. + If the service dies more than this number of times, <tt>66-svctl</tt> will exit 111 with an error message if the <em>services</em> still hasn't reached the desired state. + This option has <strong>no effects</strong> if a <em>maxdeath</em> was defined for the given service at the parsing time—see <tt><a href="66-frontend.html">frontend</a></tt>. + In such case priority is given to this file. If the option is not given and the <em>max-death-tally</em> files doesn't exist, 3 is pick by default. + </li> + <li> + <tt>-u|U </tt> : sends a up signal to the <em>service</em> where <tt>U</tt> asks for readiness notification. In case of <tt>U</tt>, <tt>66-svctl</tt> look after a <em>notification-fd</em> + file—see <tt><a href="https://skarnet.org/software/s6/notifywhenup.html">service startup notifications</a></tt> and <tt><a href="66-frontend.html">frontend</a></tt>. + In such case priority is given to this file. If such file doesn't exist, <tt>66-svctl</tt> will change the <tt>U</tt> to <tt>u</tt> and warn the user about the change. + </li> + <li> + <tt>-d|D </tt> : sends a down signal to the <em>service</em> where <tt>D</tt> asks for readiness notification. In case of <tt>D</tt>, <tt>66-svctl</tt> look after a <em>notification-fd</em> + file—see <tt><a href="https://skarnet.org/software/s6/notifywhenup.html">service startup notifications</a></tt> and <tt><a href="66-frontend.html">frontend</a></tt>. + In such case priority is given to this file. If such file doesn't exist, <tt>66-svctl</tt> will change the <tt>D</tt> to <tt>d</tt> and warn the user about the change. + </li> + </ul> +<h2> Note </h2> +<p>You can sends a signal to a <em>'classic'</em> service with the <tt><a href="https://skarnet.org/software/s6/s6-svc.html">s6-svc</a></tt> program. <tt>s6-svc</tt> has the philosophy <em>"launch and forget"</em> +and do not take care of the exit status of the service when a signal is sends. <tt>s6-svctl</tt> does. Futhermore, the <tt>-S</tt> and <tt>-n</tt> allow you to deal directly on the command line with the +<em>timeout-up</em> and <em>timeout-down</em> options even if those files doesn't exist.</p> +</body> +</html> diff --git a/doc/66-tree.html b/doc/66-tree.html index c9257019280d7c4ea0504476c95e3fef3b21193a..4abf64930a41d32329fd6588c58eba706dac0128 100644 --- a/doc/66-tree.html +++ b/doc/66-tree.html @@ -23,7 +23,7 @@ <h2> Interface </h2> <pre> - 66-tree [ -h help ] [ -v <em>verbosity</em> ] [ -n new ] [ -a allow <em>user,user,...</em> ] [ -d deny <em>user,user,...</em> ] [ -c current ] [ -E enable ] [ -D disable ] [ -R remove ] [ -C <em>clone</em> ] <em>tree</em>" + 66-tree [ -h help ] [ -v <em>verbosity</em> ] [ -n new ] [ -a allow <em>user,user,...</em> ] [ -d deny <em>user,user,...</em> ] [ -c current ] [ -E enable ] [ -D disable ] [ -R remove ] [ -C <em>clone</em> ] <em>tree</em> </pre> <p> diff --git a/doc/66-vm.mpg b/doc/66-vm.mpg new file mode 100644 index 0000000000000000000000000000000000000000..0c1751d19e70e4f8319943ff286a7cc679374aa0 Binary files /dev/null and b/doc/66-vm.mpg differ diff --git a/doc/execl-cmdline.html b/doc/execl-cmdline.html new file mode 100644 index 0000000000000000000000000000000000000000..c5874d607814917fd2bf1ecd5847deb58bae94a9 --- /dev/null +++ b/doc/execl-cmdline.html @@ -0,0 +1,83 @@ +<html> + <head> + <meta name="viewport" content="width=device-width, initial-scale=1.0" /> + <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> + <meta http-equiv="Content-Language" content="en" /> + <title>The 66 Suite: execl-cmdline</title> + <meta name="Description" content="Detailed documentation for the execl-cmdline command which is part of the 66 software suite" /> + <meta name="Keywords" content="66 command execl-cmdline service supervision execute script execline" /> + <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> --> + </head> +<body> + +<p> +<a href="index.html">66</a><br /> +<a href="//obarun.org/">www.obarun.org</a> +</p> + +<h1>execl-cmdline</h1> + + <p> + This command parse a <em>command</em> line into an <a href="https://skarnet.org/software/execline"><tt>execline</tt></a> script. + </p> + + +<h2> Interface </h2> + + <p> + In an <a href="execlineb.html">execlineb</a> script: + </p> + + <pre> + execl-cmdline -S { <em>command</em> } + </pre> + + <ul> + <li> + <tt>execl-cmdline</tt> reads the <em>command</em> and remove all space or 'no word' found before executing it. + </li> + <li> + <tt>execl-cmdline</tt> will exit with the exit code of the <em>command</em>. + </li> + </ul> + +<h2> Options </h2> + + <ul> + <li> + <tt>-S </tt> : split into separate words a command considered as one word by <em>execline</em> scripting language. + </li> + </ul> + +<h2> Note and usage examples </h2> + <p><tt>execl-cmdline</tt> should be used at the end of the <em>execline</em> scripts. If you want run another program after the call of <tt>execl-cmdline</tt> you need to use e.g + <a href="https://skarnet.org/software/execline/if.html"><tt>if</tt></a> command, <a href="https://skarnet.org/software/execline/foreground.html"><tt>foreground</tt></a>, + <a href="https://skarnet.org/software/execline/background.html"><tt>background</tt></a>, ...</p> + <p> + The following <em>command</em>: + <pre> + execl-cmdline { /usr/bin/ntpd -d "" -S } + </pre> + will give: + <pre> + /usr/bin/ntpd "-d" "-S" + </pre> + </p> + <p> + The following <em>command</em>: + <pre> + execl-cmdline -S { /usr/bin/ntpd "-d -S" } + </pre> + will give: + <pre> + /usr/bin/ntpd "-d" "-S" + </pre> + </p> + <p> + To run another program after the call of <em>execl-cmdline</em> program: + <pre> + foreground { execl-cmdline { /usr/bin/ntpd -d "" -S } } + </pre> + </p> +</body> +</html> diff --git a/src/66/66-svctl.c b/src/66/66-svctl.c index 77c0196f684c9114a3a45d9abb1cc4e9f1daccfa..8ebb7219154227c703b6a3707fb48123a5f06cd6 100644 --- a/src/66/66-svctl.c +++ b/src/66/66-svctl.c @@ -192,7 +192,7 @@ int handle_signal_svc(svc_sig *sv_signal) * * timeout-up and timeout-down will define the deadline for the iopause * each service contain his deadline into the sv_signal.deadline key. - * If thoses files doesn't exit 3000 millisec is set by default. + * If thoses files doesn't exit 1000 millisec is set by default. * This deadline value can be set on commandline by the -S options. * max-death-tally * We let s6-supervise make what it need to do with this file but