From f9d3b57b16e7a2188a8aff52bb1f451a070f8350 Mon Sep 17 00:00:00 2001 From: geosolutions Date: Wed, 28 Jun 2017 11:59:44 +0100 Subject: [PATCH] - Make processbot more resilient to errors --- src/wpsremote/processbot.py | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/wpsremote/processbot.py b/src/wpsremote/processbot.py index 7e0ebc8..165c823 100644 --- a/src/wpsremote/processbot.py +++ b/src/wpsremote/processbot.py @@ -148,23 +148,23 @@ def run(self): self.bus.Listen() def SpawnProcess(self): - logger = logging.getLogger("ProcessBot.SpawnProcess") - self.ensure_output_dir_exists() + try: + logger = logging.getLogger("ProcessBot.SpawnProcess") + self.ensure_output_dir_exists() - #set the actual value of input parameters to input parameters definitions - self._input_parameters_defs.set_values( self._input_values ) + #set the actual value of input parameters to input parameters definitions + self._input_parameters_defs.set_values( self._input_values ) - #execute actions associated to input parameters - self._input_params_actions.execute( self._input_parameters_defs ) + #execute actions associated to input parameters + self._input_params_actions.execute( self._input_parameters_defs ) - #prepare cmd line - cmd = self._executable_cmd + " " + self._input_params_actions.get_cmd_line() + #prepare cmd line + cmd = self._executable_cmd + " " + self._input_params_actions.get_cmd_line() - #spawn the computational job process - invoked_process = subprocess.Popen(args=cmd.split(), cwd=self._executable_path, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, shell=False) - logger.info("process " + self.service + " created with PId " + str(invoked_process.pid) + " and command line: " + cmd) + #spawn the computational job process + invoked_process = subprocess.Popen(args=cmd.split(), cwd=self._executable_path, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, shell=False) + logger.info("process " + self.service + " created with PId " + str(invoked_process.pid) + " and command line: " + cmd) - try: #read the resource file rc = resource_cleaner.Resource.create_from_file(self._uniqueExeId, os.getpid()) #add the pid of the computational job to the resource file