Package org.apache.activemq.network

Source Code of org.apache.activemq.network.MBeanBridgeDestination

/**
* 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.activemq.network;

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

import javax.management.ObjectName;
import org.apache.activemq.broker.BrokerService;
import org.apache.activemq.broker.jmx.AnnotatedMBean;
import org.apache.activemq.broker.jmx.BrokerMBeanSupport;
import org.apache.activemq.broker.jmx.NetworkBridgeView;
import org.apache.activemq.broker.jmx.NetworkDestinationView;
import org.apache.activemq.command.ActiveMQDestination;
import org.apache.activemq.command.Message;
import org.apache.activemq.thread.Scheduler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class MBeanBridgeDestination {
    private static final Logger LOG = LoggerFactory.getLogger(MBeanBridgeDestination.class);
    private final BrokerService brokerService;
    private final NetworkBridge bridge;
    private final NetworkBridgeView networkBridgeView;
    private final NetworkBridgeConfiguration networkBridgeConfiguration;
    private final Scheduler scheduler;
    private final Runnable purgeInactiveDestinationViewTask;
    private Map<ActiveMQDestination, ObjectName> destinationObjectNameMap = new ConcurrentHashMap<ActiveMQDestination, ObjectName>();
    private Map<ActiveMQDestination, NetworkDestinationView> outboundDestinationViewMap = new ConcurrentHashMap<ActiveMQDestination, NetworkDestinationView>();
    private Map<ActiveMQDestination, NetworkDestinationView> inboundDestinationViewMap = new ConcurrentHashMap<ActiveMQDestination, NetworkDestinationView>();

    public MBeanBridgeDestination(BrokerService brokerService, NetworkBridgeConfiguration networkBridgeConfiguration, NetworkBridge bridge, NetworkBridgeView networkBridgeView) {
        this.brokerService = brokerService;
        this.networkBridgeConfiguration = networkBridgeConfiguration;
        this.bridge = bridge;
        this.networkBridgeView = networkBridgeView;
        this.scheduler = brokerService.getScheduler();
        purgeInactiveDestinationViewTask = new Runnable() {
            public void run() {
                purgeInactiveDestinationViews();
            }
        };
    }


    public void onOutboundMessage(Message message) {
        ActiveMQDestination destination = message.getDestination();
        NetworkDestinationView networkDestinationView = outboundDestinationViewMap.get(destination);
        if (networkDestinationView == null) {
            synchronized (destinationObjectNameMap) {
                if ((networkDestinationView = outboundDestinationViewMap.get(destination)) == null) {
                    ObjectName bridgeObjectName = bridge.getMbeanObjectName();
                    try {
                        ObjectName objectName = BrokerMBeanSupport.createNetworkOutBoundDestinationObjectName(bridgeObjectName, destination);
                        networkDestinationView = new NetworkDestinationView(networkBridgeView, destination.getPhysicalName());
                        AnnotatedMBean.registerMBean(brokerService.getManagementContext(), networkDestinationView, objectName);
                        destinationObjectNameMap.put(destination, objectName);
                        outboundDestinationViewMap.put(destination, networkDestinationView);

                    } catch (Exception e) {
                        LOG.warn("Failed to register " + destination, e);
                    }
                }
            }
        }
        networkDestinationView.messageSent();
    }


    public void onInboundMessage(Message message) {
        ActiveMQDestination destination = message.getDestination();
        NetworkDestinationView networkDestinationView = inboundDestinationViewMap.get(destination);
        if (networkDestinationView == null) {
            synchronized (destinationObjectNameMap) {
                if ((networkDestinationView = inboundDestinationViewMap.get(destination)) == null) {
                    ObjectName bridgeObjectName = bridge.getMbeanObjectName();
                    try {
                        ObjectName objectName = BrokerMBeanSupport.createNetworkInBoundDestinationObjectName(bridgeObjectName, destination);
                        networkDestinationView = new NetworkDestinationView(networkBridgeView, destination.getPhysicalName());
                        networkBridgeView.addNetworkDestinationView(networkDestinationView);
                        AnnotatedMBean.registerMBean(brokerService.getManagementContext(), networkDestinationView, objectName);
                        destinationObjectNameMap.put(destination, objectName);
                        inboundDestinationViewMap.put(destination, networkDestinationView);
                    } catch (Exception e) {
                        LOG.warn("Failed to register " + destination, e);
                    }
                }
            }
        }
        networkDestinationView.messageSent();
    }

    public void start() {
        if (networkBridgeConfiguration.isGcDestinationViews()) {
            long period = networkBridgeConfiguration.getGcSweepTime();
            if (period > 0) {
                scheduler.executePeriodically(purgeInactiveDestinationViewTask, period);
            }
        }
    }

    public void stop() {
        if (!brokerService.isUseJmx()) {
            return;
        }

        scheduler.cancel(purgeInactiveDestinationViewTask);
        for (ObjectName objectName : destinationObjectNameMap.values()) {
            try {
                if (objectName != null) {
                    brokerService.getManagementContext().unregisterMBean(objectName);
                }
            } catch (Throwable e) {
                LOG.debug("Network bridge could not be unregistered in JMX: {}", e.getMessage(), e);
            }
        }
        destinationObjectNameMap.clear();
        outboundDestinationViewMap.clear();
        inboundDestinationViewMap.clear();
    }

    private void purgeInactiveDestinationViews() {
        if (!brokerService.isUseJmx()) {
            return;
        }
        purgeInactiveDestinationView(inboundDestinationViewMap);
        purgeInactiveDestinationView(outboundDestinationViewMap);
    }

    private void purgeInactiveDestinationView(Map<ActiveMQDestination, NetworkDestinationView> map) {
        long time = System.currentTimeMillis() - networkBridgeConfiguration.getGcSweepTime();
        Map<ActiveMQDestination, NetworkDestinationView> gc = null;
        for (Map.Entry<ActiveMQDestination, NetworkDestinationView> entry : map.entrySet()) {
            if (entry.getValue().getLastAccessTime() <= time) {
                if (gc == null) {
                    gc = new HashMap<ActiveMQDestination, NetworkDestinationView>();
                }
                gc.put(entry.getKey(), entry.getValue());
            }
        }

        if (gc != null) {
            for (Map.Entry<ActiveMQDestination, NetworkDestinationView> entry : gc.entrySet()) {
                map.remove(entry.getKey());
                ObjectName objectName = destinationObjectNameMap.get(entry.getKey());
                if (objectName != null) {
                    try {
                        if (objectName != null) {
                            brokerService.getManagementContext().unregisterMBean(objectName);
                        }
                    } catch (Throwable e) {
                        LOG.debug("Network bridge could not be unregistered in JMX: {}", e.getMessage(), e);
                    }
                }
                entry.getValue().close();
            }
        }
    }

}
TOP

Related Classes of org.apache.activemq.network.MBeanBridgeDestination

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.