Compare commits
	
		
			7 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					b1d7df15ef | ||
| 
						 | 
					01088e282f | ||
| 
						 | 
					b95ae213e9 | ||
| 
						 | 
					4f544f4130 | ||
| 
						 | 
					c65bed756e | ||
| 
						 | 
					ccc81a9cad | ||
| 
						 | 
					3a1e304d6c | 
							
								
								
									
										53
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								ChangeLog
									
									
									
									
									
								
							@@ -1,3 +1,56 @@
 | 
			
		||||
commit 01088e282f08ca373ae1d61b2ed954c3075f130a
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    s6: Use s6-svc -Dd to stop services
 | 
			
		||||
    
 | 
			
		||||
    This allows us to get rid of the sleep call in the stop function. Also,
 | 
			
		||||
    we set a configurable timeout value for stopping daemons.
 | 
			
		||||
 | 
			
		||||
commit b95ae213e9435f267da3331fd4568a5ad297b54c
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    Start work on 0.16.2
 | 
			
		||||
 | 
			
		||||
commit 4f544f4130e0b62e18bdde42cad2b3aed085136d
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    update change log
 | 
			
		||||
 | 
			
		||||
commit c65bed756e5f5cfa244d9aa4325691345d8c324d
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    More s6 fixes
 | 
			
		||||
    
 | 
			
		||||
    - When no service link is in the scan directory, show the default
 | 
			
		||||
      stopped message.
 | 
			
		||||
    - Do not remove the service link when stopping the service.
 | 
			
		||||
 | 
			
		||||
commit ccc81a9cad5d9beb739593827fc4bbc04c4a3304
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    Fix the s6 handling
 | 
			
		||||
    
 | 
			
		||||
    This changes the default s6 service directory to /var/svc.d, also
 | 
			
		||||
    it changes the code to work with the individual services instead of
 | 
			
		||||
    forcing a rescan when a service is started or stopped.
 | 
			
		||||
 | 
			
		||||
commit 3a1e304d6c56875838b884b6e0608fe756ccce4e
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    Start work on 0.16.1
 | 
			
		||||
 | 
			
		||||
commit d247ac4cbbe0ab62564ef82a5940b4f1a03973b3
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 | 
			
		||||
    Update changelog
 | 
			
		||||
 | 
			
		||||
commit bb2d7becfd3008379f8f69b5d036922281aa211f
 | 
			
		||||
Author: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
Commit: William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
 
 | 
			
		||||
@@ -1,3 +1,3 @@
 | 
			
		||||
NAME=		openrc
 | 
			
		||||
VERSION=	0.16
 | 
			
		||||
VERSION=	0.16.2
 | 
			
		||||
PKG=		${NAME}-${VERSION}
 | 
			
		||||
 
 | 
			
		||||
@@ -114,11 +114,12 @@ in this release is S6 from Skarnet software. To use this, set
 | 
			
		||||
supervisor=s6.
 | 
			
		||||
.It Ar s6_service_path
 | 
			
		||||
The path to the s6 service directory if you are monitoring this service
 | 
			
		||||
with S6. The default is /etc/svc.d/${RC_SVCNAME}.
 | 
			
		||||
with S6. The default is /var/svc.d/${RC_SVCNAME}.
 | 
			
		||||
.It Ar s6_svwait_options_start
 | 
			
		||||
The options to pass to s6-svwait when starting the service via s6.
 | 
			
		||||
.It Ar s6_svwait_options_stop
 | 
			
		||||
The options to pass to s6-svwait when stopping the service via s6.
 | 
			
		||||
.It Ar s6_service_timeout_stop
 | 
			
		||||
The amount of time, in milliseconds, s6-svc should wait for the service
 | 
			
		||||
to go down when stopping the service. The default is 10000.
 | 
			
		||||
.It Ar start_stop_daemon_args
 | 
			
		||||
List of arguments passed to start-stop-daemon when starting the daemon.
 | 
			
		||||
.It Ar command
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										20
									
								
								s6-guide.md
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								s6-guide.md
									
									
									
									
									
								
							@@ -33,22 +33,14 @@ supervisor=s6
 | 
			
		||||
Several other variables affect s6 services. They are documented on the
 | 
			
		||||
openrc-run man page, but I will list them here for convenience:
 | 
			
		||||
 | 
			
		||||
s6_service_path - the path to the s6 service directory
 | 
			
		||||
s6_service_path - the path to the s6 service directory. The default is
 | 
			
		||||
/var/svc.d/$RC_SVCNAME.
 | 
			
		||||
 | 
			
		||||
s6_svwait_options_start - the options to pass to s6-svwait when starting
 | 
			
		||||
s6_svwait_options_stop - the options to pass to s6-svwait when stopping.
 | 
			
		||||
the service. If this is not set, s6-svwait will not be called.
 | 
			
		||||
 | 
			
		||||
The s6_service_path variable defaults to /etc/svc.d/${RC_SVCNAME} if it
 | 
			
		||||
is not set in the service script. For example, if you want a service
 | 
			
		||||
script called /etc/init.d/foobar to use s6 to monitor its daemon, the s6
 | 
			
		||||
service should be the directory /etc/svc.d/foobar.
 | 
			
		||||
 | 
			
		||||
See the documentation for s6 for more information about s6 service
 | 
			
		||||
directories.
 | 
			
		||||
 | 
			
		||||
The s6_svwait_options_* variables set command line options to pass to
 | 
			
		||||
s6-svwait when starting or stopping the s6 service. These can be very
 | 
			
		||||
useful for waiting for s6 services to signal when they are up, timing out
 | 
			
		||||
when an s6 service doesn't come up, etc.
 | 
			
		||||
s6_service_timeout_stop - the amount of time, in milliseconds, s6-svc
 | 
			
		||||
should wait for a service to go down when stopping.
 | 
			
		||||
 | 
			
		||||
This is very early support, so feel free to file bugs if you have
 | 
			
		||||
issues.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										38
									
								
								sh/s6.sh
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								sh/s6.sh
									
									
									
									
									
								
							@@ -2,7 +2,7 @@
 | 
			
		||||
# Copyright (c) 2015 William Hubbs <w.d.hubbs@gmail.com>
 | 
			
		||||
# Released under the 2-clause BSD license.
 | 
			
		||||
 | 
			
		||||
[ -z "${s6_service_path}" ] && s6_service_path="/etc/svc.d/${RC_SVCNAME}"
 | 
			
		||||
[ -z "${s6_service_path}" ] && s6_service_path="/var/svc.d/${RC_SVCNAME}"
 | 
			
		||||
 | 
			
		||||
s6_start()
 | 
			
		||||
{
 | 
			
		||||
@@ -10,16 +10,17 @@ s6_start()
 | 
			
		||||
		eerror "${s6_service_path} does not exist."
 | 
			
		||||
 	return 1
 | 
			
		||||
 fi
 | 
			
		||||
	local rc
 | 
			
		||||
	s6_service_link="${RC_SVCDIR}/s6-scan/${s6_service_path##*/}"
 | 
			
		||||
	ebegin "Starting ${name:-$RC_SVCNAME}"
 | 
			
		||||
	ln -sf "${s6_service_path}" "${RC_SVCDIR}"/s6-scan
 | 
			
		||||
	s6-svscanctl -an "${RC_SVCDIR}"/s6-scan
 | 
			
		||||
	rc=$?
 | 
			
		||||
	ln -sf "${s6_service_path}" "${s6_service_link}"
 | 
			
		||||
	s6-svc -u "${s6_service_link}"
 | 
			
		||||
	if [ -n "$s6_svwait_options_start" ]; then
 | 
			
		||||
		s6-svwait ${s6_svwait_options_start} "${s6_service_path}"
 | 
			
		||||
		rc=$?
 | 
			
		||||
		s6-svwait ${s6_svwait_options_start} "${s6_service_link}"
 | 
			
		||||
	fi
 | 
			
		||||
	eend $rc "Failed to start $RC_SVCNAME"
 | 
			
		||||
	sleep 1.5
 | 
			
		||||
	set -- $(s6-svstat "${s6_service_link}")
 | 
			
		||||
	[ "$1" = "up" ]
 | 
			
		||||
	eend $? "Failed to start $RC_SVCNAME"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
s6_stop()
 | 
			
		||||
@@ -28,19 +29,20 @@ s6_stop()
 | 
			
		||||
		eerror "${s6_service_path} does not exist."
 | 
			
		||||
 	return 1
 | 
			
		||||
 fi
 | 
			
		||||
	local rc
 | 
			
		||||
	s6_service_link="${RC_SVCDIR}/s6-scan/${s6_service_path##*/}"
 | 
			
		||||
	ebegin "Stopping ${name:-$RC_SVCNAME}"
 | 
			
		||||
	rm -rf "${RC_SVCDIR}/s6-scan/${s6_service_path##*/}"
 | 
			
		||||
	s6-svscanctl -an "${RC_SVCDIR}"/s6-scan
 | 
			
		||||
	rc=$? 
 | 
			
		||||
	if [ -n "$s6_svwait_options_stop" ]; then
 | 
			
		||||
		s6-svwait ${s6_svwait_options_stop} "${s6_service_path}"
 | 
			
		||||
		rc=$?
 | 
			
		||||
	fi
 | 
			
		||||
	eend $rc "Failed to stop $RC_SVCNAME"
 | 
			
		||||
	s6-svc -Dd -T ${s6_service_timeout_stop:-10000} "${s6_service_link}"
 | 
			
		||||
	set -- $(s6-svstat "${s6_service_link}")
 | 
			
		||||
	[ "$1" = "down" ]
 | 
			
		||||
	eend $? "Failed to stop $RC_SVCNAME"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
s6_status()
 | 
			
		||||
{
 | 
			
		||||
	s6-svstat "${s6_service_path}"
 | 
			
		||||
	s6_service_link="${RC_SVCDIR}/s6-scan/${s6_service_path##*/}"
 | 
			
		||||
	if [ -L "${s6_service_link}" ]; then
 | 
			
		||||
		s6-svstat "${s6_service_link}"
 | 
			
		||||
	else
 | 
			
		||||
		_status
 | 
			
		||||
	fi
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user