Search in sources :

Example 16 with Group

use of io.fabric8.kubernetes.model.annotation.Group in project fabric8 by jboss-fuse.

the class FabricMQGateway method createListener.

protected GatewayServiceTreeCache createListener() {
    String zkPath = getZooKeeperPath();
    // TODO we should discover the broker group configuration here using the same
    // mq-create / mq-client profiles so that we only listen to a subset of the available brokers here?
    ServiceMap serviceMap = new ServiceMap();
    VertxService vertxService = getVertxService();
    Vertx vertx = vertxService.getVertx();
    CuratorFramework curator = getCurator();
    LoadBalancer pathLoadBalancer = LoadBalancers.createLoadBalancer(loadBalancerType, stickyLoadBalancerCacheSize);
    LoadBalancer serviceLoadBalancer = LoadBalancers.createLoadBalancer(loadBalancerType, stickyLoadBalancerCacheSize);
    LOG.info("activating MQ mapping ZooKeeper path: " + zkPath + " host: " + host + " with load balancer: " + pathLoadBalancer);
    List<TcpGateway> gateways = new ArrayList<TcpGateway>();
    addGateway(gateways, vertx, serviceMap, "tcp", isOpenWireEnabled(), getOpenWirePort(), pathLoadBalancer, serviceLoadBalancer);
    addGateway(gateways, vertx, serviceMap, "stomp", isStompEnabled(), getStompPort(), pathLoadBalancer, serviceLoadBalancer);
    addGateway(gateways, vertx, serviceMap, "amqp", isAmqpEnabled(), getAmqpPort(), pathLoadBalancer, serviceLoadBalancer);
    addGateway(gateways, vertx, serviceMap, "mqtt", isMqttEnabled(), getMqttPort(), pathLoadBalancer, serviceLoadBalancer);
    addGateway(gateways, vertx, serviceMap, "ws", isWebsocketEnabled(), getWebsocketPort(), pathLoadBalancer, serviceLoadBalancer);
    if (gateways.isEmpty()) {
        return null;
    }
    return new GatewayServiceTreeCache(curator, zkPath, serviceMap, gateways);
}
Also used : CuratorFramework(org.apache.curator.framework.CuratorFramework) ServiceMap(io.fabric8.gateway.ServiceMap) TcpGateway(io.fabric8.gateway.handlers.tcp.TcpGateway) VertxService(io.fabric8.gateway.fabric.support.vertx.VertxService) ArrayList(java.util.ArrayList) LoadBalancer(io.fabric8.gateway.loadbalancer.LoadBalancer) Vertx(org.vertx.java.core.Vertx)

Example 17 with Group

use of io.fabric8.kubernetes.model.annotation.Group in project fabric8 by jboss-fuse.

the class GatewayServiceTreeCache method init.

public void init() throws Exception {
    if (active.compareAndSet(false, true)) {
        treeCache = new TreeCacheExtended(curator, zkPath, true, false, true, treeCacheExecutor);
        treeCache.start(TreeCacheExtended.StartMode.NORMAL);
        treeCache.getListenable().addListener(treeListener);
        LOG.info("Started a group listener for " + zkPath);
        for (TcpGateway gateway : gateways) {
            gateway.init();
        }
    }
}
Also used : TcpGateway(io.fabric8.gateway.handlers.tcp.TcpGateway) TreeCacheExtended(org.apache.curator.framework.recipes.cache.TreeCacheExtended)

Example 18 with Group

use of io.fabric8.kubernetes.model.annotation.Group in project fabric8 by jboss-fuse.

the class FabricDiscoveryAgent method initGroup.

private synchronized void initGroup() throws Exception {
    group = (MultiGroup) factory.createMultiGroup("/fabric/registry/clusters/amq/" + groupName, ActiveMQNode.class, new NamedThreadFactory("zkgroup-fabric-mq-discovery"));
    group.add(new GroupListener<ActiveMQNode>() {

        @Override
        public void groupEvent(Group<ActiveMQNode> group, GroupEvent event) {
            LOG.debug("Event: " + event);
            Map<String, ActiveMQNode> masters = new HashMap<String, ActiveMQNode>();
            for (ActiveMQNode node : group.members().values()) {
                if (!masters.containsKey(node.id)) {
                    masters.put(node.id, node);
                }
            }
            update(masters.values());
        }
    });
}
Also used : NamedThreadFactory(io.fabric8.utils.NamedThreadFactory) HashMap(java.util.HashMap) Map(java.util.Map)

Example 19 with Group

use of io.fabric8.kubernetes.model.annotation.Group in project fabric8-maven-plugin by fabric8io.

the class MavenProjectEnricherTest method testGeneratedResources.

@Test
public void testGeneratedResources() {
    ProjectLabelEnricher projectEnricher = new ProjectLabelEnricher(context);
    KubernetesListBuilder builder = createListWithDeploymentConfig();
    projectEnricher.enrich(PlatformMode.kubernetes, builder);
    KubernetesList list = builder.build();
    Map<String, String> labels = list.getItems().get(0).getMetadata().getLabels();
    assertNotNull(labels);
    assertEquals("groupId", labels.get("group"));
    assertEquals("artifactId", labels.get("app"));
    assertEquals("version", labels.get("version"));
    assertNull(labels.get("project"));
    builder = new KubernetesListBuilder().withItems(new DeploymentBuilder().build());
    projectEnricher.create(PlatformMode.kubernetes, builder);
    Deployment deployment = (Deployment) builder.buildFirstItem();
    Map<String, String> selectors = deployment.getSpec().getSelector().getMatchLabels();
    assertEquals("groupId", selectors.get("group"));
    assertEquals("artifactId", selectors.get("app"));
    assertNull(selectors.get("version"));
    assertNull(selectors.get("project"));
}
Also used : KubernetesListBuilder(io.fabric8.kubernetes.api.model.KubernetesListBuilder) Deployment(io.fabric8.kubernetes.api.model.apps.Deployment) KubernetesList(io.fabric8.kubernetes.api.model.KubernetesList) DeploymentBuilder(io.fabric8.kubernetes.api.model.apps.DeploymentBuilder) Test(org.junit.Test)

Example 20 with Group

use of io.fabric8.kubernetes.model.annotation.Group in project fabric8-maven-plugin by fabric8io.

the class MavenProjectEnricherTest method testOldStyleGeneratedResources.

@Test
public void testOldStyleGeneratedResources() {
    final Properties properties = new Properties();
    properties.setProperty("fabric8.enricher.fmp-project-label.useProjectLabel", "true");
    new Expectations() {

        {
            context.getConfiguration();
            result = new Configuration.Builder().properties(properties).build();
        }
    };
    ProjectLabelEnricher projectEnricher = new ProjectLabelEnricher(context);
    KubernetesListBuilder builder = createListWithDeploymentConfig();
    projectEnricher.enrich(PlatformMode.kubernetes, builder);
    KubernetesList list = builder.build();
    Map<String, String> labels = list.getItems().get(0).getMetadata().getLabels();
    assertNotNull(labels);
    assertEquals("groupId", labels.get("group"));
    assertEquals("artifactId", labels.get("project"));
    assertEquals("version", labels.get("version"));
    assertNull(labels.get("app"));
    builder = new KubernetesListBuilder().withItems(new DeploymentConfigBuilder().build());
    projectEnricher.create(PlatformMode.kubernetes, builder);
    DeploymentConfig deploymentConfig = (DeploymentConfig) builder.buildFirstItem();
    Map<String, String> selectors = deploymentConfig.getSpec().getSelector();
    assertEquals("groupId", selectors.get("group"));
    assertEquals("artifactId", selectors.get("project"));
    assertNull(selectors.get("version"));
    assertNull(selectors.get("app"));
}
Also used : Expectations(mockit.Expectations) KubernetesListBuilder(io.fabric8.kubernetes.api.model.KubernetesListBuilder) Configuration(io.fabric8.maven.core.model.Configuration) DeploymentConfigBuilder(io.fabric8.openshift.api.model.DeploymentConfigBuilder) KubernetesList(io.fabric8.kubernetes.api.model.KubernetesList) Properties(java.util.Properties) DeploymentConfig(io.fabric8.openshift.api.model.DeploymentConfig) Test(org.junit.Test)

Aggregations

Test (org.junit.jupiter.api.Test)30 Test (org.junit.Test)24 IOException (java.io.IOException)16 ArrayList (java.util.ArrayList)16 Map (java.util.Map)15 KubernetesClient (io.fabric8.kubernetes.client.KubernetesClient)13 HashMap (java.util.HashMap)12 CuratorFramework (org.apache.curator.framework.CuratorFramework)12 File (java.io.File)11 List (java.util.List)11 ObjectMapper (com.fasterxml.jackson.databind.ObjectMapper)10 GenericKafkaListenerBuilder (io.strimzi.api.kafka.model.listener.arraylistener.GenericKafkaListenerBuilder)10 ParallelNamespaceTest (io.strimzi.systemtest.annotations.ParallelNamespaceTest)10 Collectors (java.util.stream.Collectors)9 ZooKeeperGroup (io.fabric8.groups.internal.ZooKeeperGroup)8 Pod (io.fabric8.kubernetes.api.model.Pod)8 KubernetesClientBuilder (io.fabric8.kubernetes.client.KubernetesClientBuilder)8 KafkaUser (io.strimzi.api.kafka.model.KafkaUser)8 RetryNTimes (org.apache.curator.retry.RetryNTimes)8 Tag (org.junit.jupiter.api.Tag)8