Как встроить Tomcat 6?

В настоящее время я работаю над своими веб-приложениями на Tomcat 6 и хотел бы оценить работу Tomcat во встроенном режиме.

Есть ли хороший учебник или другой ресурс, кроме того, что в документации API?

6 ответов

Кодекс говорит сам за себя. Смотрите фрагмент pom.xml и класс для запуска tomcat.

    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>catalina</artifactId>
        <version>6.0.18</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>coyote</artifactId>
        <version>6.0.18</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.apache.tomcat</groupId>
        <artifactId>jasper</artifactId>
        <version>6.0.18</version>
        <scope>test</scope>
    </dependency>


public class RunWebApplicationTomcat {

    private String path = null;
    private Embedded container = null;
    private Log logger = LogFactory.getLog(getClass());

    /**
     * The directory to create the Tomcat server configuration under.
     */
    private String catalinaHome = "tomcat";

    /**
     * The port to run the Tomcat server on.
     */
    private int port = 8089;

    /**
     * The classes directory for the web application being run.
     */
    private String classesDir = "target/classes";

    /**
     * The web resources directory for the web application being run.
     */
    private String webappDir = "mywebapp";

    /**
     * Creates a single-webapp configuration to be run in Tomcat on port 8089. If module name does
     * not conform to the 'contextname-webapp' convention, use the two-args constructor.
     * 
     * @param contextName without leading slash, for example, "mywebapp"
     * @throws IOException
     */
    public RunWebApplicationTomcat(String contextName) {
        Assert.isTrue(!contextName.startsWith("/"));
        path = "/" + contextName;
    }

    /**
     * Starts the embedded Tomcat server.
     * 
     * @throws LifecycleException
     * @throws MalformedURLException if the server could not be configured
     * @throws LifecycleException if the server could not be started
     * @throws MalformedURLException
     */
    public void run(int port) throws LifecycleException, MalformedURLException {
        this.port = port;
        // create server
        container = new Embedded();
        container.setCatalinaHome(catalinaHome);
        container.setRealm(new MemoryRealm());

        // create webapp loader
        WebappLoader loader = new WebappLoader(this.getClass().getClassLoader());

        if (classesDir != null) {
            loader.addRepository(new File(classesDir).toURI().toURL().toString());
        }

        // create context
        // TODO: Context rootContext = container.createContext(path, webappDir);
        Context rootContext = container.createContext(path, webappDir);
        rootContext.setLoader(loader);
        rootContext.setReloadable(true);

        // create host
        // String appBase = new File(catalinaHome, "webapps").getAbsolutePath();
        Host localHost = container.createHost("localHost", new File("target").getAbsolutePath());
        localHost.addChild(rootContext);

        // create engine
        Engine engine = container.createEngine();
        engine.setName("localEngine");
        engine.addChild(localHost);
        engine.setDefaultHost(localHost.getName());
        container.addEngine(engine);

        // create http connector
        Connector httpConnector = container.createConnector((InetAddress) null, port, false);
        container.addConnector(httpConnector);

        container.setAwait(true);

        // start server
        container.start();

        // add shutdown hook to stop server
        Runtime.getRuntime().addShutdownHook(new Thread() {
            public void run() {
                stopContainer();
            }
        });
    }
    /**
     * Stops the embedded Tomcat server.
     */
    public void stopContainer() {
        try {
            if (container != null) {
                container.stop();
            }
        } catch (LifecycleException exception) {
            logger.warn("Cannot Stop Tomcat" + exception.getMessage());
        }
    }

    public String getPath() {
        return path;
    }

    public void setPath(String path) {
        this.path = path;
    }

    public static void main(String[] args) throws Exception {
        RunWebApplicationTomcat inst = new RunWebApplicationTomcat("mywebapp");
        inst.run(8089);
    }

    public int getPort() {
        return port;
    }

}

Хотя этот пост несколько постарел, я отвечаю на свой собственный ответ, так как это может сэкономить время для других

package com.creativefella;

import org.apache.catalina.Engine;
import org.apache.catalina.Host;
import org.apache.catalina.LifecycleException;
import org.apache.catalina.connector.Connector;
import org.apache.catalina.core.StandardContext;
import org.apache.catalina.startup.Embedded;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class TomcatServer {
    private Embedded server;
    private int port;
    private boolean isRunning;

    private static final Logger LOG = LoggerFactory.getLogger(TomcatServer.class);
    private static final boolean isInfo = LOG.isInfoEnabled();


/**
 * Create a new Tomcat embedded server instance. Setup looks like:
 * <pre><Server>
 *    <Service>
 *        <Connector />
 *        <Engine&gt
 *            <Host>
 *                <Context />
 *            </Host>
 *        </Engine>
 *    </Service>
 *</Server></pre>
 * <Server> & <Service> will be created automcatically. We need to hook the remaining to an {@link Embedded} instnace
 * @param contextPath Context path for the application
 * @param port Port number to be used for the embedded Tomcat server
 * @param appBase Path to the Application files (for Maven based web apps, in general: <code>/src/main/</code>)
 * @param shutdownHook If true, registers a server' shutdown hook with JVM. This is useful to shutdown the server
 *                      in erroneous cases.
 * @throws Exception
 */
    public TomcatServer(String contextPath, int port, String appBase, boolean shutdownHook) {
        if(contextPath == null || appBase == null || appBase.length() == 0) {
            throw new IllegalArgumentException("Context path or appbase should not be null");
        }
        if(!contextPath.startsWith("/")) {
            contextPath = "/" + contextPath;
        }

        this.port = port;

        server  = new Embedded();
        server.setName("TomcatEmbeddedServer");

        Host localHost = server.createHost("localhost", appBase);
        localHost.setAutoDeploy(false);

        StandardContext rootContext = (StandardContext) server.createContext(contextPath, "webapp");
        rootContext.setDefaultWebXml("web.xml");
        localHost.addChild(rootContext);

        Engine engine = server.createEngine();
        engine.setDefaultHost(localHost.getName());
        engine.setName("TomcatEngine");
        engine.addChild(localHost);

        server.addEngine(engine);

        Connector connector = server.createConnector(localHost.getName(), port, false);
        server.addConnector(connector);

        // register shutdown hook
        if(shutdownHook) {
            Runtime.getRuntime().addShutdownHook(new Thread() {
                public void run() {
                    if(isRunning) {
                        if(isInfo) LOG.info("Stopping the Tomcat server, through shutdown hook");
                        try {
                            if (server != null) {
                                server.stop();
                            }
                        } catch (LifecycleException e) {
                            LOG.error("Error while stopping the Tomcat server, through shutdown hook", e);
                        }
                    }
                }
            });
        }

    }

    /**
     * Start the tomcat embedded server
     */
    public void start() throws LifecycleException {
        if(isRunning) {
            LOG.warn("Tomcat server is already running @ port={}; ignoring the start", port);
            return;
        }

        if(isInfo) LOG.info("Starting the Tomcat server @ port={}", port);

        server.setAwait(true);
        server.start();
        isRunning = true;
    }

    /**
     * Stop the tomcat embedded server
     */
    public void stop() throws LifecycleException {
        if(!isRunning) {
            LOG.warn("Tomcat server is not running @ port={}", port);
            return;
        }

        if(isInfo) LOG.info("Stopping the Tomcat server");

        server.stop();
        isRunning = false;
    }

    public boolean isRunning() {
        return isRunning;
    }

}

Я также столкнулся с 404 ошибка и боролись некоторое время. Увидев бревно INFO: No default web.xml "Я подозревал, что (если это предупреждение, было бы легко заметить). Хитрость в использовании web.xml ( rootContext.setDefaultWebXml("web.xml") ) поставляется с Tomcat ( conf/web.xml ) Причина в том, что он включает DefaultServlet, который обслуживает статические файлы, такие как HTML, JS. Либо использовать web.xml или зарегистрируйте сервлет вручную в своем коде.

Использование:

// start the server at http://localhost:8080/myapp
TomcatServer server = new TomcatServer("myapp", 8080, "/src/main/", true);
server.start();
// .....
server.stop();

Не забудьте разместить по умолчанию web.xml в том же каталоге этой программы или укажите на правильное местоположение.

Следует отметить, что отключение крюка вдохновлено ответом Антонио.

Существует несколько причин, по которым можно использовать Tomcat поверх Jetty:

  1. Один уже знаком с Tomcat
  2. Одним из них является разработка веб-приложений, которые необходимо легко перенести в установку Tomcat.
  3. Документация разработчика Jetty на самом деле более точная, чем у Tomcat (удивительно!)
  4. Ответы на вопросы в сообществе Jetty могут иногда занимать годы, как в 2007 году.
  5. Важное замечание: После Jetty 6.1.* Каждое веб-приложение открывается в свою собственную JVM, поэтому если вы пытаетесь получить программный доступ между автономным доступом и веб-приложением, ваша единственная надежда - через веб-API.
  6. Если это проблема для вас, Tomcat - это проект с открытым исходным кодом, интеллектуальная собственность которого принадлежит Apache Foundation, Jetty - с открытым исходным кодом, но принадлежит небольшой частной компании (Mortbay Consulting).

Пункт № 5 был важным в моей работе. Например, я могу получить прямой доступ к экземпляру JSPWiki через Tomcat, но он совершенно недоступен при использовании Jetty. Я попросил решение этой проблемы в 2007 году и пока не услышал ответ. Поэтому я, наконец, сдался и начал использовать Tomcat 6. Я изучил Glassfish и Grizzly, но пока что Tomcat является (удивительно) самым стабильным и хорошо документированным веб-контейнером (который на самом деле мало что говорит).

Это может помочь.

Если вы скачаете исходный пакет для Tomcat6.x, вы получите этот класс:

http://tomcat.apache.org/tomcat-6.0-doc/api/org/apache/catalina/startup/Catalina.html

Вот пример того, как использовать класс Embedd: это оболочка для остановки | запуска определенной установки Tomcat. (Я имею в виду, вы можете настроить CATALINA_BASE указать на существующую установку Tomcat).

Если вы скомпилируете это, вы можете запустить так:

Java -D"catalina.base=%CATALINA_BASE%" -D"catalina.home=%CATALINA_HOME%" org.apache.catalina.startup.Catalina start

Я еще не уверен, как изменить этот код для выключения сервера!

Прочитав эту ветку несколько месяцев назад, я написал этот проект: https://github.com/alx3apps/spring-embedded-tomcat. Его можно использовать для встраивания tomcat6 в приложения на основе Spring.

Я думаю, что с Tomcat 7 или Jetty 9 встраивание проще. Здесь вы найдете хорошее введение: http://www.hascode.com/2013/07/embedding-jetty-or-tomcat-in-your-java-application/

Другие вопросы по тегам