Repository: camel
Updated Branches:
  refs/heads/camel-2.18.x b0e35cb47 -> 49adc55b7


CAMEL-11020: Camel Kubernetes consumers do not close watchers - Pods Consumer


Project: http://git-wip-us.apache.org/repos/asf/camel/repo
Commit: http://git-wip-us.apache.org/repos/asf/camel/commit/c2add9fd
Tree: http://git-wip-us.apache.org/repos/asf/camel/tree/c2add9fd
Diff: http://git-wip-us.apache.org/repos/asf/camel/diff/c2add9fd

Branch: refs/heads/camel-2.18.x
Commit: c2add9fd951f6acbf49a30f0e1909e6f116861df
Parents: b0e35cb
Author: Andrea Cosentino <anco...@gmail.com>
Authored: Thu Mar 16 11:46:49 2017 +0100
Committer: Andrea Cosentino <anco...@gmail.com>
Committed: Thu Mar 16 13:08:58 2017 +0100

----------------------------------------------------------------------
 .../consumer/KubernetesPodsConsumer.java        | 25 +++++++++++++++++---
 1 file changed, 22 insertions(+), 3 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/camel/blob/c2add9fd/components/camel-kubernetes/src/main/java/org/apache/camel/component/kubernetes/consumer/KubernetesPodsConsumer.java
----------------------------------------------------------------------
diff --git 
a/components/camel-kubernetes/src/main/java/org/apache/camel/component/kubernetes/consumer/KubernetesPodsConsumer.java
 
b/components/camel-kubernetes/src/main/java/org/apache/camel/component/kubernetes/consumer/KubernetesPodsConsumer.java
index 24947b0..9abf29b 100644
--- 
a/components/camel-kubernetes/src/main/java/org/apache/camel/component/kubernetes/consumer/KubernetesPodsConsumer.java
+++ 
b/components/camel-kubernetes/src/main/java/org/apache/camel/component/kubernetes/consumer/KubernetesPodsConsumer.java
@@ -22,6 +22,7 @@ import io.fabric8.kubernetes.api.model.DoneablePod;
 import io.fabric8.kubernetes.api.model.Pod;
 import io.fabric8.kubernetes.api.model.PodList;
 import io.fabric8.kubernetes.client.KubernetesClientException;
+import io.fabric8.kubernetes.client.Watch;
 import io.fabric8.kubernetes.client.Watcher;
 import io.fabric8.kubernetes.client.dsl.ClientMixedOperation;
 import io.fabric8.kubernetes.client.dsl.ClientNonNamespaceOperation;
@@ -43,6 +44,7 @@ public class KubernetesPodsConsumer extends DefaultConsumer {
 
     private final Processor processor;
     private ExecutorService executor;
+    private PodsConsumerTask podsWatcher;
 
     public KubernetesPodsConsumer(KubernetesEndpoint endpoint, Processor 
processor) {
         super(endpoint, processor);
@@ -58,8 +60,9 @@ public class KubernetesPodsConsumer extends DefaultConsumer {
     protected void doStart() throws Exception {
         super.doStart();
         executor = getEndpoint().createExecutor();
-
-        executor.submit(new PodsConsumerTask());
+        
+        podsWatcher = new PodsConsumerTask();
+        executor.submit(podsWatcher);
     }
 
     @Override
@@ -69,8 +72,14 @@ public class KubernetesPodsConsumer extends DefaultConsumer {
         LOG.debug("Stopping Kubernetes Pods Consumer");
         if (executor != null) {
             if (getEndpoint() != null && getEndpoint().getCamelContext() != 
null) {
+                if (podsWatcher != null) {
+                    podsWatcher.getWatch().close();
+                }
                 
getEndpoint().getCamelContext().getExecutorServiceManager().shutdownNow(executor);
             } else {
+                if (podsWatcher != null) {
+                    podsWatcher.getWatch().close();
+                }
                 executor.shutdownNow();
             }
         }
@@ -78,6 +87,8 @@ public class KubernetesPodsConsumer extends DefaultConsumer {
     }
 
     class PodsConsumerTask implements Runnable {
+
+        private Watch watch;
         
         @Override
         public void run() {
@@ -92,7 +103,7 @@ public class KubernetesPodsConsumer extends DefaultConsumer {
             if 
(ObjectHelper.isNotEmpty(getEndpoint().getKubernetesConfiguration().getResourceName()))
 {
                 
w.withName(getEndpoint().getKubernetesConfiguration().getResourceName());
             }
-            w.watch(new Watcher<Pod>() {
+            watch = w.watch(new Watcher<Pod>() {
 
                 @Override
                 public void 
eventReceived(io.fabric8.kubernetes.client.Watcher.Action action,
@@ -117,6 +128,14 @@ public class KubernetesPodsConsumer extends 
DefaultConsumer {
 
                 }
             });
+        }
+
+        public Watch getWatch() {
+            return watch;
+        }
+
+        public void setWatch(Watch watch) {
+            this.watch = watch;
         } 
     }
 }

Reply via email to