diff --git a/parsl/providers/kubernetes/kube.py b/parsl/providers/kubernetes/kube.py index 5a69d160fb..166781cf8d 100644 --- a/parsl/providers/kubernetes/kube.py +++ b/parsl/providers/kubernetes/kube.py @@ -195,9 +195,9 @@ def submit(self, cmd_string: str, tasks_per_node: int, job_name: str = "parsl.ku volumes=self.persistent_volumes, service_account_name=self.service_account_name, annotations=self.annotations) - self.resources[pod_name] = {'status': JobStatus(JobState.RUNNING)} + self.resources[job_id] = {'status': JobStatus(JobState.RUNNING), 'pod_name': pod_name} - return pod_name + return job_id def status(self, job_ids): """ Get the status of a list of jobs identified by the job identifiers @@ -213,6 +213,9 @@ def status(self, job_ids): self._status() return [self.resources[jid]['status'] for jid in job_ids] + def _get_pod_name(self, job_id: str) -> str: + return self.resources[job_id]['pod_name'] + def cancel(self, job_ids): """ Cancels the jobs specified by a list of job ids Args: @@ -222,7 +225,8 @@ def cancel(self, job_ids): """ for job in job_ids: logger.debug("Terminating job/pod: {0}".format(job)) - self._delete_pod(job) + pod_name = self._get_pod_name(job) + self._delete_pod(pod_name) self.resources[job]['status'] = JobStatus(JobState.CANCELLED) rets = [True for i in job_ids] @@ -243,7 +247,8 @@ def _status(self): for jid in to_poll_job_ids: phase = None try: - pod = self.kube_client.read_namespaced_pod(name=jid, namespace=self.namespace) + pod_name = self._get_pod_name(jid) + pod = self.kube_client.read_namespaced_pod(name=pod_name, namespace=self.namespace) except Exception: logger.exception("Failed to poll pod {} status, most likely because pod was terminated".format(jid)) if self.resources[jid]['status'] is JobStatus(JobState.RUNNING):