Commit 35de3ee1 authored by Jérome Perrin's avatar Jérome Perrin

slapgrid: explicitly close partition file logger for instanciation

reorganise a bit the code so that resources that we cleanup in finally:
happens just before the try:

Also, remove the handler in finally case, partitions that where failing
again and again apparently added handler again and again.
parent 79a91fb4
Pipeline #5732 passed with stage
...@@ -1066,9 +1066,7 @@ stderr_logfile_backups=1 ...@@ -1066,9 +1066,7 @@ stderr_logfile_backups=1
# Include Partition Logging # Include Partition Logging
log_folder_path = "%s/.slapgrid/log" % instance_path log_folder_path = "%s/.slapgrid/log" % instance_path
mkdir_p(log_folder_path) mkdir_p(log_folder_path)
partition_file_handler = logging.FileHandler(
filename="%s/instance.log" % (log_folder_path)
)
stat_info = os.stat(instance_path) stat_info = os.stat(instance_path)
chownDirectory("%s/.slapgrid" % instance_path, chownDirectory("%s/.slapgrid" % instance_path,
uid=stat_info.st_uid, uid=stat_info.st_uid,
...@@ -1076,9 +1074,13 @@ stderr_logfile_backups=1 ...@@ -1076,9 +1074,13 @@ stderr_logfile_backups=1
formatter = logging.Formatter( formatter = logging.Formatter(
'[%(asctime)s] %(levelname)-8s %(name)s %(message)s') '[%(asctime)s] %(levelname)-8s %(name)s %(message)s')
# this partition_file_handler will be cleaned up after this try: block
partition_file_handler = logging.FileHandler(
filename="%s/instance.log" % (log_folder_path)
)
partition_file_handler.setFormatter(formatter) partition_file_handler.setFormatter(formatter)
self.logger.addHandler(partition_file_handler) self.logger.addHandler(partition_file_handler)
try: try:
self.logger.info('Processing Computer Partition %s.' % computer_partition_id) self.logger.info('Processing Computer Partition %s.' % computer_partition_id)
self.logger.info(' Software URL: %s' % software_url) self.logger.info(' Software URL: %s' % software_url)
...@@ -1155,8 +1157,9 @@ stderr_logfile_backups=1 ...@@ -1155,8 +1157,9 @@ stderr_logfile_backups=1
# updating promises state, no need to raise here # updating promises state, no need to raise here
pass pass
raise e raise e
else: finally:
self.logger.removeHandler(partition_file_handler) self.logger.removeHandler(partition_file_handler)
partition_file_handler.close()
# Run manager tear down # Run manager tear down
for manager in self._manager_list: for manager in self._manager_list:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment