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

org.cometd.oort.OortMulticastConfigServlet Maven / Gradle / Ivy

/*
 * Copyright (c) 2010 the original author or authors.
 *
 * Licensed 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.cometd.oort;

import java.net.InetAddress;
import java.net.MulticastSocket;
import javax.servlet.ServletConfig;

import org.cometd.bayeux.server.BayeuxServer;

/**
 * 

This servlet initializes and configures an instance of the {@link Oort} * CometD cluster manager via autodiscovery of other Oort comets using UDP multicast.

*

This servlet configures and starts an instance of {@link OortMulticastConfigurer} * that advertises via multicast the Oort URL to which it is associated and * receives the advertisements from other Oort comets.

*

This servlet must be initialized after an instance the CometD servlet * that creates the {@link BayeuxServer} instance used by {@link Oort}.

*

This servlet inherits from {@link OortConfigServlet} init parameters used * to configure the Oort instance, and adds the following init parameters:

*
    *
  • oort.multicast.bindAddress, to specify the bind address of the * {@link MulticastSocket} that receives the advertisements; defaults to the wildcard * address
  • *
  • oort.multicast.groupAddress, to specify the multicast group address * to join to receive the advertisements; defaults to 239.255.0.1
  • *
  • oort.multicast.groupPort, to specify the port over which advertisements * are sent and received; defaults to 5577
  • *
  • oort.multicast.timeToLive, to specify the time to live of advertisement packets; * defaults to 1 (1 = same subnet, 32 = same site, 255 = global)
  • *
  • oort.multicast.advertiseInterval, to specify the interval in milliseconds * at which advertisements are sent; defaults to 1000 ms
  • *
* * @see OortConfigServlet * @see OortMulticastConfigServlet */ public class OortMulticastConfigServlet extends OortConfigServlet { public static final String OORT_MULTICAST_BIND_ADDRESS_PARAM = "oort.multicast.bindAddress"; public static final String OORT_MULTICAST_GROUP_ADDRESS_PARAM = "oort.multicast.groupAddress"; public static final String OORT_MULTICAST_GROUP_PORT_PARAM = "oort.multicast.groupPort"; public static final String OORT_MULTICAST_TIME_TO_LIVE_PARAM = "oort.multicast.timeToLive"; public static final String OORT_MULTICAST_ADVERTISE_INTERVAL_PARAM = "oort.multicast.advertiseInterval"; private OortMulticastConfigurer configurer; @Override protected void configureCloud(ServletConfig config, Oort oort) throws Exception { configurer = new OortMulticastConfigurer(oort); String bindAddress = config.getInitParameter(OORT_MULTICAST_BIND_ADDRESS_PARAM); if (bindAddress != null) configurer.setBindAddress(InetAddress.getByName(bindAddress)); String groupAddress = config.getInitParameter(OORT_MULTICAST_GROUP_ADDRESS_PARAM); if (groupAddress != null) configurer.setGroupAddress(InetAddress.getByName(groupAddress)); String groupPort = config.getInitParameter(OORT_MULTICAST_GROUP_PORT_PARAM); if (groupPort != null) configurer.setGroupPort(Integer.parseInt(groupPort)); String timeToLive = config.getInitParameter(OORT_MULTICAST_TIME_TO_LIVE_PARAM); if (timeToLive != null) configurer.setTimeToLive(Integer.parseInt(timeToLive)); String advertiseInterval = config.getInitParameter(OORT_MULTICAST_ADVERTISE_INTERVAL_PARAM); if (advertiseInterval != null) configurer.setAdvertiseInterval(Long.parseLong(advertiseInterval)); configurer.start(); } @Override public void destroy() { if (configurer != null) { configurer.stop(); configurer.join(1000); } super.destroy(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy