All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.brooklyn.entity.webapp.ControlledDynamicWebAppCluster Maven / Gradle / Ivy

There is a newer version: 1.1.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.brooklyn.entity.webapp;

import org.apache.brooklyn.api.catalog.Catalog;
import org.apache.brooklyn.api.entity.Entity;
import org.apache.brooklyn.api.entity.EntitySpec;
import org.apache.brooklyn.api.entity.Group;
import org.apache.brooklyn.api.entity.ImplementedBy;
import org.apache.brooklyn.api.sensor.AttributeSensor;
import org.apache.brooklyn.config.ConfigKey;
import org.apache.brooklyn.core.config.ConfigKeys;
import org.apache.brooklyn.core.entity.Attributes;
import org.apache.brooklyn.core.entity.lifecycle.Lifecycle;
import org.apache.brooklyn.core.entity.trait.MemberReplaceable;
import org.apache.brooklyn.core.entity.trait.Resizable;
import org.apache.brooklyn.core.entity.trait.Startable;
import org.apache.brooklyn.core.sensor.BasicAttributeSensor;
import org.apache.brooklyn.core.sensor.BasicAttributeSensorAndConfigKey;
import org.apache.brooklyn.entity.group.Cluster;
import org.apache.brooklyn.entity.group.DynamicCluster;
import org.apache.brooklyn.entity.group.DynamicGroup;
import org.apache.brooklyn.entity.proxy.LoadBalancer;
import org.apache.brooklyn.util.core.flags.SetFromFlag;

/**
 * This entity contains the sub-groups and entities that go in to a single location (e.g. datacenter)
 * to provide web-app cluster functionality, viz load-balancer (controller) and webapp software processes.
 * 

* You can customise the web server by customising the memberSpec. *

* The children of this entity are: *

    *
  • a {@link org.apache.brooklyn.entity.group.DynamicCluster} of {@link WebAppService}s (defaults to JBoss7Server) *
  • a cluster controller (defaulting to Nginx if none supplied) *
* * This entity is also a group whose members mirror those of the child DynamicCluster (so do not include the load balancer). * This is convenient for associating policies such as ServiceReplacer with this entity, rather * than with the child {@link org.apache.brooklyn.entity.group.DynamicCluster}. However, note that changing this entity's * members has no effect on the members of the underlying DynamicCluster - treat this as a read-only view. */ @Catalog(name="Controlled Dynamic Web-app Cluster", description="A cluster of load-balanced web-apps, which can be dynamically re-sized") @ImplementedBy(ControlledDynamicWebAppClusterImpl.class) public interface ControlledDynamicWebAppCluster extends DynamicGroup, Entity, Startable, Resizable, MemberReplaceable, Group, JavaWebAppService, JavaWebAppService.CanDeployAndUndeploy, JavaWebAppService.CanRedeployAll { @SetFromFlag("initialSize") public static ConfigKey INITIAL_SIZE = ConfigKeys.newConfigKeyWithDefault(Cluster.INITIAL_SIZE, 1); @SetFromFlag("controller") public static BasicAttributeSensorAndConfigKey CONTROLLER = new BasicAttributeSensorAndConfigKey( LoadBalancer.class, "controlleddynamicwebappcluster.controller", "Controller for the cluster; if null a default will created (using controllerSpec)"); @SetFromFlag("controlledGroup") public static BasicAttributeSensorAndConfigKey CONTROLLED_GROUP = new BasicAttributeSensorAndConfigKey( Group.class, "controlleddynamicwebappcluster.controlledgroup", "The group of web servers that the controller should point at; if null, will use the CLUSTER"); @SuppressWarnings({ "unchecked", "rawtypes" }) @SetFromFlag("controllerSpec") public static BasicAttributeSensorAndConfigKey> CONTROLLER_SPEC = new BasicAttributeSensorAndConfigKey( EntitySpec.class, "controlleddynamicwebappcluster.controllerSpec", "Spec for creating the controller (if one not supplied explicitly); if null an NGINX instance will be created"); @SuppressWarnings({ "unchecked", "rawtypes" }) /** Spec for web server entiites to be created */ @SetFromFlag("memberSpec") public static BasicAttributeSensorAndConfigKey> MEMBER_SPEC = new BasicAttributeSensorAndConfigKey( EntitySpec.class, DynamicCluster.MEMBER_SPEC.getName(), "Spec for web server entiites to be created"); @SuppressWarnings({ "unchecked", "rawtypes" }) @SetFromFlag("webClusterSpec") public static BasicAttributeSensorAndConfigKey> WEB_CLUSTER_SPEC = new BasicAttributeSensorAndConfigKey( EntitySpec.class, "controlleddynamicwebappcluster.webClusterSpec", "Spec for creating the cluster; if null a DynamicWebAppCluster will be created"); public static AttributeSensor CLUSTER = new BasicAttributeSensor( DynamicWebAppCluster.class, "controlleddynamicwebappcluster.cluster", "Underlying web-app cluster"); public static final AttributeSensor HOSTNAME = Attributes.HOSTNAME; public static final AttributeSensor SERVICE_STATE_ACTUAL = Attributes.SERVICE_STATE_ACTUAL; public LoadBalancer getController(); public DynamicWebAppCluster getCluster(); public Group getControlledGroup(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy