Write log pusher PID to PID file.
The Jenkins log pusher daemon was not writing its PID to its PID file. This prevented init from properly stopping the service. Write the PID out to the file to fix this. Change-Id: I35352b6e241b54a439f3675d02344d901249dff1 Reviewed-on: https://review.openstack.org/29578 Reviewed-by: James E. Blair <corvus@inaugust.com> Approved: Clark Boylan <clark.boylan@gmail.com> Reviewed-by: Clark Boylan <clark.boylan@gmail.com> Tested-by: Jenkins
This commit is contained in:
parent
67e81cc7fa
commit
ff66c84a94
@ -397,14 +397,16 @@ class DaemonContext(object):
|
|||||||
os.chdir(os.sep)
|
os.chdir(os.sep)
|
||||||
|
|
||||||
# Lock pidfile.
|
# Lock pidfile.
|
||||||
self.pidfile = open(self.pidfile_path, 'w')
|
self.pidfile = open(self.pidfile_path, 'a')
|
||||||
try:
|
try:
|
||||||
fcntl.lockf(self.pidfile, fcntl.LOCK_EX | fcntl.LOCK_NB)
|
fcntl.lockf(self.pidfile, fcntl.LOCK_EX | fcntl.LOCK_NB)
|
||||||
self.pidlocked = True
|
self.pidlocked = True
|
||||||
except IOError:
|
except IOError:
|
||||||
# another instance is running
|
# another instance is running
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
# TODO(clarkb) write pid to pidfile
|
self.pidfile.truncate(0)
|
||||||
|
self.pidfile.write(str(os.getpid()))
|
||||||
|
self.pidfile.flush()
|
||||||
|
|
||||||
def __exit__(self, exc_type, exc_value, traceback):
|
def __exit__(self, exc_type, exc_value, traceback):
|
||||||
# remove pidfile
|
# remove pidfile
|
||||||
|
Loading…
Reference in New Issue
Block a user