Added override for swift-init's KILL_WAIT
You can now give swift-init a -k N (or --kill-wait N) option to override the default 15 second wait for a process to die after sending it the die signal. This is useful for boxes that are awfully slow for whatever reason. DocImpact Change-Id: I328ec254f6e0ee1cd423c1d062ba4c5331bd8337
This commit is contained in:
parent
2a9bf20065
commit
4fcbeff22f
@ -17,7 +17,8 @@
|
|||||||
import sys
|
import sys
|
||||||
from optparse import OptionParser
|
from optparse import OptionParser
|
||||||
|
|
||||||
from swift.common.manager import Server, Manager, UnknownCommandError
|
from swift.common.manager import Server, Manager, UnknownCommandError, \
|
||||||
|
KILL_WAIT
|
||||||
|
|
||||||
USAGE = """%prog <server> [<server> ...] <command> [options]
|
USAGE = """%prog <server> [<server> ...] <command> [options]
|
||||||
|
|
||||||
@ -42,6 +43,9 @@ def main():
|
|||||||
parser.add_option('-c', '--config-num', metavar="N", type="int",
|
parser.add_option('-c', '--config-num', metavar="N", type="int",
|
||||||
dest="number", default=0,
|
dest="number", default=0,
|
||||||
help="send command to the Nth server only")
|
help="send command to the Nth server only")
|
||||||
|
parser.add_option('-k', '--kill-wait', metavar="N", type="int",
|
||||||
|
dest="kill_wait", default=KILL_WAIT,
|
||||||
|
help="wait N seconds for processes to die (default 15)")
|
||||||
options, args = parser.parse_args()
|
options, args = parser.parse_args()
|
||||||
|
|
||||||
if len(args) < 2:
|
if len(args) < 2:
|
||||||
|
@ -107,6 +107,7 @@ allows one to use the keywords such as "all", "main" and "rest" for the <server>
|
|||||||
.IP "-n, --no-daemon \t\t start server interactively
|
.IP "-n, --no-daemon \t\t start server interactively
|
||||||
.IP "-g, --graceful \t\t send SIGHUP to supporting servers
|
.IP "-g, --graceful \t\t send SIGHUP to supporting servers
|
||||||
.IP "-c N, --config-num=N \t send command to the Nth server only
|
.IP "-c N, --config-num=N \t send command to the Nth server only
|
||||||
|
.IP "-k N, --kill-wait=N \t wait N seconds for processes to die (default 15)
|
||||||
.PD
|
.PD
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ START_ONCE_SERVERS = REST_SERVERS
|
|||||||
# don't use that type-server.conf file and instead use their own.
|
# don't use that type-server.conf file and instead use their own.
|
||||||
STANDALONE_SERVERS = ['object-expirer']
|
STANDALONE_SERVERS = ['object-expirer']
|
||||||
|
|
||||||
KILL_WAIT = 15 # seconds to wait for servers to die
|
KILL_WAIT = 15 # seconds to wait for servers to die (by default)
|
||||||
WARNING_WAIT = 3 # seconds to wait after message that may just be a warning
|
WARNING_WAIT = 3 # seconds to wait after message that may just be a warning
|
||||||
|
|
||||||
MAX_DESCRIPTORS = 32768
|
MAX_DESCRIPTORS = 32768
|
||||||
@ -218,8 +218,9 @@ class Manager():
|
|||||||
for p in pids]
|
for p in pids]
|
||||||
# keep track of the pids yeiled back as killed for all servers
|
# keep track of the pids yeiled back as killed for all servers
|
||||||
killed_pids = set()
|
killed_pids = set()
|
||||||
|
kill_wait = kwargs.get('kill_wait', KILL_WAIT)
|
||||||
for server, killed_pid in watch_server_pids(server_pids,
|
for server, killed_pid in watch_server_pids(server_pids,
|
||||||
interval=KILL_WAIT,
|
interval=kill_wait,
|
||||||
**kwargs):
|
**kwargs):
|
||||||
print _("%s (%s) appears to have stopped") % (server, killed_pid)
|
print _("%s (%s) appears to have stopped") % (server, killed_pid)
|
||||||
killed_pids.add(killed_pid)
|
killed_pids.add(killed_pid)
|
||||||
@ -232,7 +233,7 @@ class Manager():
|
|||||||
if not killed_pids.issuperset(pids):
|
if not killed_pids.issuperset(pids):
|
||||||
# some pids of this server were not killed
|
# some pids of this server were not killed
|
||||||
print _('Waited %s seconds for %s to die; giving up') % (
|
print _('Waited %s seconds for %s to die; giving up') % (
|
||||||
KILL_WAIT, server)
|
kill_wait, server)
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
@command
|
@command
|
||||||
|
Loading…
Reference in New Issue
Block a user