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

org.jboss.as.ee.subsystem.ManagedExecutorTerminateHungTasksOperation Maven / Gradle / Ivy

There is a newer version: 35.0.0.Beta1
Show newest version
/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */
package org.jboss.as.ee.subsystem;

import org.jboss.as.controller.AbstractRuntimeOnlyHandler;
import org.jboss.as.controller.OperationContext;
import org.jboss.as.controller.OperationFailedException;
import org.jboss.as.controller.RunningMode;
import org.jboss.as.controller.SimpleOperationDefinition;
import org.jboss.as.controller.SimpleOperationDefinitionBuilder;
import org.jboss.as.controller.capability.RuntimeCapability;
import org.jboss.as.controller.descriptions.ResourceDescriptionResolver;
import org.jboss.as.controller.registry.ManagementResourceRegistration;
import org.jboss.as.ee.concurrent.ManagedExecutorWithHungThreads;
import org.jboss.as.ee.logging.EeLogger;
import org.jboss.dmr.ModelNode;
import org.jboss.msc.service.ServiceController;
import org.jboss.msc.service.ServiceName;

/**
 * Operation that manually terminates a managed executor's hung tasks, through its capability service.
 *
 * @author emmartins
 */
public class ManagedExecutorTerminateHungTasksOperation {

    public static final String NAME = "terminate-hung-tasks";

    private final RuntimeCapability capability;
    private final SimpleOperationDefinition operationDefinition;
    private final ExecutorProvider executorProvider;

    /**
     *
     * @param capability
     * @param resolver
     * @param executorProvider
     */
    ManagedExecutorTerminateHungTasksOperation(final RuntimeCapability capability, ResourceDescriptionResolver resolver, ExecutorProvider executorProvider) {
        this.capability = capability;
        this.operationDefinition = new SimpleOperationDefinitionBuilder(NAME, resolver)
                .setRuntimeOnly()
                .build();
        this.executorProvider = executorProvider;
    }

    /**
     * Registers this operation with the specified resource.
     * @param resourceRegistration
     */
    void registerOperation(ManagementResourceRegistration resourceRegistration) {
        if (resourceRegistration.getProcessType().isServer()) {
            resourceRegistration.registerOperationHandler(operationDefinition, new AbstractRuntimeOnlyHandler() {
                @Override
                protected void executeRuntimeStep(OperationContext context, ModelNode operation) throws OperationFailedException {
                    if (context.getRunningMode() == RunningMode.NORMAL) {
                        ServiceName serviceName = capability.getCapabilityServiceName(context.getCurrentAddress());
                        ServiceController controller = context.getServiceRegistry(false).getService(serviceName);
                        if (controller == null) {
                            throw EeLogger.ROOT_LOGGER.executorServiceNotFound(serviceName);
                        }
                        final T service = (T) controller.getService();
                        ManagedExecutorWithHungThreads executor = executorProvider.getExecutor(service);
                        executor.terminateHungTasks();
                    }
                    context.completeStep(OperationContext.RollbackHandler.NOOP_ROLLBACK_HANDLER);
                }
            });
        }
    }

    /**
     * Component which retrieves executors with hung threads, from services.
     * @param 
     */
    interface ExecutorProvider {
        /**
         *
         * @param service
         * @return the executor with the specified service
         */
        ManagedExecutorWithHungThreads getExecutor(T service);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy