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

com.aspectran.undertow.server.DefaultTowServer Maven / Gradle / Ivy

There is a newer version: 8.1.5
Show newest version
/*
 * Copyright (c) 2008-2024 The Aspectran Project
 *
 * Licensed 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 com.aspectran.undertow.server;

import com.aspectran.core.component.bean.ablility.DisposableBean;
import com.aspectran.core.component.bean.ablility.InitializableBean;
import com.aspectran.utils.logging.Logger;
import com.aspectran.utils.logging.LoggerFactory;
import io.undertow.Undertow;
import io.undertow.server.handlers.GracefulShutdownHandler;
import io.undertow.servlet.api.DeploymentManager;

/**
 * The Undertow Server managed by Aspectran.
 *
 * @see Undertow
 * @since 6.3.0
 */
public class DefaultTowServer extends AbstractTowServer implements InitializableBean, DisposableBean {

    private static final Logger logger = LoggerFactory.getLogger(DefaultTowServer.class);

    private Undertow server;

    @Override
    public void doStart() throws Exception {
        try {
            server = getBuilder().build();
            server.start();
            logger.info("Undertow " + TowServer.getVersion() + " started");
        } catch (Exception e) {
            try {
                if (server != null) {
                    server.stop();
                    server = null;
                }
            } catch (Exception ex) {
                // ignore
            }
            throw new Exception("Unable to start Undertow server", e);
        }
    }

    @Override
    public void doStop() {
        if (server != null) {
            try {
                if (getHandler() instanceof GracefulShutdownHandler shutdownHandler) {
                    shutdownHandler.shutdown();
                    try {
                        if (getShutdownTimeoutSecs() > 0) {
                            // Wait "30" seconds before make a force shutdown
                            boolean result = shutdownHandler.awaitShutdown(getShutdownTimeoutSecs() * 1000L);
                            if (!result) {
                                logger.warn("Undertow server did not shut down gracefully within " +
                                    getShutdownTimeoutSecs() + " seconds. Proceeding with forceful shutdown");
                            }
                        } else {
                            shutdownHandler.awaitShutdown();
                        }
                    } catch (Exception ex) {
                        logger.error("Unable to gracefully stop Undertow server");
                    }
                }
                if (getServletContainer() != null) {
                    for (String deploymentName : getServletContainer().listDeployments()) {
                        DeploymentManager manager = getServletContainer().getDeployment(deploymentName);
                        if (manager != null) {
                            manager.stop();
                            manager.undeploy();
                        }
                    }
                }
                server.stop();
                server = null;
                logger.info("Undertow " + TowServer.getVersion() + " stopped");
            } catch (Exception e) {
                logger.error("Unable to stop Undertow server", e);
            }
        }
    }

    @Override
    public void initialize() throws Exception {
        if (isAutoStart()) {
            start();
        }
    }

    @Override
    public void destroy() {
        try {
            stop();
        } catch (Exception e) {
            logger.error("Error while stopping Undertow server", e);
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy