io.fabric8.mq.model.Model Maven / Gradle / Ivy
/*
*
* * Copyright 2005-2015 Red Hat, Inc.
* * Red Hat 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 io.fabric8.mq.model;
import com.codahale.metrics.MetricRegistry;
import io.fabric8.mq.coordination.brokers.BrokerModel;
import io.fabric8.mq.multiplexer.Multiplexer;
import io.fabric8.mq.multiplexer.MultiplexerInput;
import org.apache.activemq.Service;
import org.apache.activemq.command.ActiveMQDestination;
import javax.management.ObjectName;
import java.util.Collection;
import java.util.List;
import java.util.Set;
public interface Model extends Service {
String DEFAULT_JMX_DOMAIN = "io.fabric8.mq";
MetricRegistry METRIC_REGISTRY = new MetricRegistry();
BrokerLimitsConfig getBrokerLimitsConfig();
void add(Multiplexer multiplexer);
void remove(Multiplexer multiplexer);
void add(MultiplexerInput multiplexer);
void remove(MultiplexerInput multiplexer);
void add(BrokerModel brokerModel);
void remove(BrokerModel brokerModel);
void register(MultiplexerInput multiplexer, DestinationStatisticsMBean destinationStatistics);
void unregister(MultiplexerInput multiplexer, DestinationStatisticsMBean destinationStatistics);
boolean areBrokerLimitsExceeded(BrokerModel brokerModel);
boolean areBrokerConnectionLimitsExceeded(BrokerModel brokerModel);
boolean areDestinationLimitsExceeded(BrokerModel brokerModel);
BrokerModel getMostLoadedBroker();
BrokerModel getNextLeastLoadedBroker(BrokerModel brokerModel);
BrokerModel getLeastLoadedBroker();
int getLoad(BrokerModel brokerModel);
BrokerModel getBrokerById(String id);
Collection getBrokers();
List getSortedDestinations(BrokerModel brokerModel, int maxNumber);
List getSortedDestinations(BrokerModel brokerModel);
Set getActiveDestinations(BrokerModel brokerModel);
int getBrokerCount();
Set getBrokersForDestination(ActiveMQDestination destination);
void addBrokerForDestination(ActiveMQDestination destination, BrokerModel brokerModel);
int spareConnections(BrokerModel brokerModel);
int spareDestinations(BrokerModel brokerModel);
boolean isMaximumNumberOfBrokersReached();
BrokerModel addBrokerForDestination(ActiveMQDestination destination);
void removeBrokerFromDestination(ActiveMQDestination destination, BrokerModel brokerModel);
boolean copyDestinations(BrokerModel from, BrokerModel to);
boolean copyDestinations(BrokerModel from, BrokerModel to, Collection destinations);
void registerInJmx(ObjectName objectName, Object object) throws Exception;
void unregisterInJmx(Object object);
void dispatched(MultiplexerInput MultiplexerInput, ActiveMQDestination destination);
void acked(MultiplexerInput MultiplexerInput, ActiveMQDestination destination);
void unregister(MultiplexerInput MultiplexerInput);
void stopDispatching(ActiveMQDestination destination);
public void startDispatching(ActiveMQDestination destination);
boolean canDispatch(ActiveMQDestination destination);
boolean isStoppedDispatching(ActiveMQDestination destination);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy