/** * 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.camel.management; import javax.management.ObjectName; import org.apache.camel.CamelContext; import org.apache.camel.Endpoint; import org.apache.camel.management.mbean.ManagedBacklogDebugger; import org.apache.camel.management.mbean.ManagedBacklogTracer; import org.apache.camel.management.mbean.ManagedCamelContext; import org.apache.camel.management.mbean.ManagedComponent; import org.apache.camel.management.mbean.ManagedConsumer; import org.apache.camel.management.mbean.ManagedDataFormat; import org.apache.camel.management.mbean.ManagedEndpoint; import org.apache.camel.management.mbean.ManagedErrorHandler; import org.apache.camel.management.mbean.ManagedEventNotifier; import org.apache.camel.management.mbean.ManagedProcessor; import org.apache.camel.management.mbean.ManagedProducer; import org.apache.camel.management.mbean.ManagedRoute; import org.apache.camel.management.mbean.ManagedService; import org.apache.camel.management.mbean.ManagedThreadPool; import org.apache.camel.management.mbean.ManagedTracer; import org.apache.camel.model.ProcessorDefinition; import org.apache.camel.spi.ManagementAgent; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * A JMX capable {@link org.apache.camel.spi.ManagementStrategy} that Camel by default uses if possible. * <p/> * Camel detects whether its possible to use this JMX capable strategy and if <b>not</b> then Camel * will fallback to the {@link org.apache.camel.management.DefaultManagementStrategy} instead. * * @see org.apache.camel.spi.ManagementStrategy * @see org.apache.camel.management.DefaultManagementStrategy * @version */ public class ManagedManagementStrategy extends DefaultManagementStrategy { private static final Logger LOG = LoggerFactory.getLogger(ManagedManagementStrategy.class); public ManagedManagementStrategy() { } @Deprecated public ManagedManagementStrategy(ManagementAgent managementAgent) { setManagementAgent(managementAgent); } public ManagedManagementStrategy(CamelContext camelContext, ManagementAgent managementAgent) { setCamelContext(camelContext); setManagementAgent(managementAgent); } public void manageObject(Object managedObject) throws Exception { manageNamedObject(managedObject, null); } public void manageNamedObject(Object managedObject, Object preferredName) throws Exception { ObjectName objectName = getObjectName(managedObject, preferredName); if (objectName != null) { getManagementAgent().register(managedObject, objectName); } } public <T> T getManagedObjectName(Object managedObject, String customName, Class<T> nameType) throws Exception { if (managedObject == null) { return null; } ObjectName objectName = null; if (managedObject instanceof ManagedCamelContext) { ManagedCamelContext mcc = (ManagedCamelContext) managedObject; objectName = getManagementNamingStrategy().getObjectNameForCamelContext(mcc.getContext()); } else if (managedObject instanceof ManagedComponent) { ManagedComponent mc = (ManagedComponent) managedObject; objectName = getManagementNamingStrategy().getObjectNameForComponent(mc.getComponent(), mc.getComponentName()); } else if (managedObject instanceof ManagedDataFormat) { ManagedDataFormat md = (ManagedDataFormat) managedObject; objectName = getManagementNamingStrategy().getObjectNameForDataFormat(md.getContext(), md.getDataFormat()); } else if (managedObject instanceof ManagedEndpoint) { ManagedEndpoint me = (ManagedEndpoint) managedObject; objectName = getManagementNamingStrategy().getObjectNameForEndpoint(me.getEndpoint()); } else if (managedObject instanceof Endpoint) { objectName = getManagementNamingStrategy().getObjectNameForEndpoint((Endpoint) managedObject); } else if (managedObject instanceof ManagedRoute) { ManagedRoute mr = (ManagedRoute) managedObject; objectName = getManagementNamingStrategy().getObjectNameForRoute(mr.getRoute()); } else if (managedObject instanceof ManagedErrorHandler) { ManagedErrorHandler meh = (ManagedErrorHandler) managedObject; objectName = getManagementNamingStrategy().getObjectNameForErrorHandler(meh.getRouteContext(), meh.getErrorHandler(), meh.getErrorHandlerBuilder()); } else if (managedObject instanceof ManagedProcessor) { ManagedProcessor mp = (ManagedProcessor) managedObject; objectName = getManagementNamingStrategy().getObjectNameForProcessor(mp.getContext(), mp.getProcessor(), mp.getDefinition()); } else if (managedObject instanceof ManagedConsumer) { ManagedConsumer ms = (ManagedConsumer) managedObject; objectName = getManagementNamingStrategy().getObjectNameForConsumer(ms.getContext(), ms.getConsumer()); } else if (managedObject instanceof ManagedProducer) { ManagedProducer ms = (ManagedProducer) managedObject; objectName = getManagementNamingStrategy().getObjectNameForProducer(ms.getContext(), ms.getProducer()); } else if (managedObject instanceof ManagedTracer) { ManagedTracer mt = (ManagedTracer) managedObject; objectName = getManagementNamingStrategy().getObjectNameForTracer(mt.getContext(), mt.getTracer()); } else if (managedObject instanceof ManagedBacklogTracer) { ManagedBacklogTracer mt = (ManagedBacklogTracer) managedObject; objectName = getManagementNamingStrategy().getObjectNameForTracer(mt.getContext(), mt.getBacklogTracer()); } else if (managedObject instanceof ManagedBacklogDebugger) { ManagedBacklogDebugger md = (ManagedBacklogDebugger) managedObject; objectName = getManagementNamingStrategy().getObjectNameForTracer(md.getContext(), md.getBacklogDebugger()); } else if (managedObject instanceof ManagedEventNotifier) { ManagedEventNotifier men = (ManagedEventNotifier) managedObject; objectName = getManagementNamingStrategy().getObjectNameForEventNotifier(men.getContext(), men.getEventNotifier()); } else if (managedObject instanceof ManagedThreadPool) { ManagedThreadPool mes = (ManagedThreadPool) managedObject; objectName = getManagementNamingStrategy().getObjectNameForThreadPool(mes.getContext(), mes.getThreadPool(), mes.getId(), mes.getSourceId()); } else if (managedObject instanceof ManagedService) { // check for managed service should be last ManagedService ms = (ManagedService) managedObject; // skip endpoints as they are already managed if (ms.getService() instanceof Endpoint) { return null; } objectName = getManagementNamingStrategy().getObjectNameForService(ms.getContext(), ms.getService()); } return nameType.cast(objectName); } public void unmanageObject(Object managedObject) throws Exception { ObjectName objectName = getManagedObjectName(managedObject, null, ObjectName.class); unmanageNamedObject(objectName); } public void unmanageNamedObject(Object name) throws Exception { ObjectName objectName = getObjectName(null, name); if (objectName != null) { getManagementAgent().unregister(objectName); } } public boolean isManaged(Object managedObject, Object name) { try { ObjectName objectName = getObjectName(managedObject, name); if (objectName != null) { return getManagementAgent().isRegistered(objectName); } } catch (Exception e) { LOG.warn("Cannot check whether the managed object is registered. This exception will be ignored.", e); } return false; } @Override public boolean manageProcessor(ProcessorDefinition<?> definition) { return true; } private ObjectName getObjectName(Object managedObject, Object preferedName) throws Exception { ObjectName objectName; if (preferedName != null && preferedName instanceof String) { String customName = (String) preferedName; objectName = getManagedObjectName(managedObject, customName, ObjectName.class); } else if (preferedName != null && preferedName instanceof ObjectName) { objectName = (ObjectName) preferedName; } else { objectName = getManagedObjectName(managedObject, null, ObjectName.class); } return objectName; } @Override protected void doStart() throws Exception { LOG.info("JMX is enabled"); doStartManagementStrategy(); } }