001/** 002 * Licensed to the Apache Software Foundation (ASF) under one or more 003 * contributor license agreements. See the NOTICE file distributed with 004 * this work for additional information regarding copyright ownership. 005 * The ASF licenses this file to You under the Apache License, Version 2.0 006 * (the "License"); you may not use this file except in compliance with 007 * the License. You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017package org.apache.camel.api.management.mbean; 018 019import javax.management.openmbean.TabularData; 020 021import org.apache.camel.api.management.ManagedAttribute; 022import org.apache.camel.api.management.ManagedOperation; 023 024public interface ManagedAsyncProcessorAwaitManagerMBean extends ManagedServiceMBean { 025 026 @ManagedAttribute(description = "Whether to interrupt any blocking threads during stopping.") 027 boolean isInterruptThreadsWhileStopping(); 028 029 @ManagedAttribute(description = "Whether to interrupt any blocking threads during stopping.") 030 void setInterruptThreadsWhileStopping(boolean interruptThreadsWhileStopping); 031 032 @ManagedAttribute(description = "Number of threads that are blocked waiting for other threads to trigger the callback when they are done processing the exchange") 033 int getSize(); 034 035 @ManagedOperation(description = "Lists all the exchanges which are currently inflight, having a blocked thread awaiting for other threads to trigger the callback when they are done") 036 TabularData browse(); 037 038 @ManagedOperation(description = "To interrupt an exchange which may seem as stuck, to force the exchange to continue, allowing any blocking thread to be released.") 039 void interrupt(String exchangeId); 040 041 @ManagedAttribute(description = "Number of threads that has been blocked") 042 long getThreadsBlocked(); 043 044 @ManagedAttribute(description = "Number of threads that has been interrupted") 045 long getThreadsInterrupted(); 046 047 @ManagedAttribute(description = "Total wait time in msec.") 048 long getTotalDuration(); 049 050 @ManagedAttribute(description = "The minimum wait time in msec.") 051 long getMinDuration(); 052 053 @ManagedAttribute(description = "The maximum wait time in msec.") 054 long getMaxDuration(); 055 056 @ManagedAttribute(description = "The average wait time in msec.") 057 long getMeanDuration(); 058 059 @ManagedOperation(description = "Resets the statistics") 060 void resetStatistics(); 061 062 @ManagedAttribute(description = "Utilization statistics enabled") 063 boolean isStatisticsEnabled(); 064 065 @ManagedAttribute(description = "Utilization statistics enabled") 066 void setStatisticsEnabled(boolean statisticsEnabled); 067 068}