我正在使用Tomcat来服务我的Java Servlets,这对我来说更有用。我只需要服务,单独使用Servlet请求,没有静态内容,也不需要JSP等。所以我一直在寻找可以嵌入到我的应用程序中的Servlet容器。我觉得如果剥离Jetty并单独使用它作为Servlet容器,它可以更具可扩展性并占用很小的内存空间,[我不需要Jetty的'Web Server'和其他部件]。所以我有几个问题,
我打算用我的应用程序提供API请求,我正在寻找性能和可伸缩性作为主要约束。当然还有Servlet 3.0支持。
答案 0 :(得分:16)
您正在寻找的是在嵌入式场景中运行Jetty。
有很多例子可以展示如何将实现目标所需的各个部分联系在一起。
查看embedded examples in the jetty source tree。
为了记录,jetty standalone实际上只是一个嵌入了一些启动和类路径相关引导的jetty。它是相同的代码,并以基本相同的方式组装。
既然你说你想要Servlet 3.0,对JSP没兴趣,这很容易设置。 (JSP设置起来比较棘手,但可能)。
对于servlet 3.0特定的嵌入,在github上有一个完整的示例项目。
https://github.com/jetty-project/embedded-servlet-3.0
简而言之,您将拥有以下初始化代码。
package com.company.foo;
import org.eclipse.jetty.annotations.AnnotationConfiguration;
import org.eclipse.jetty.plus.webapp.EnvConfiguration;
import org.eclipse.jetty.plus.webapp.PlusConfiguration;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.webapp.Configuration;
import org.eclipse.jetty.webapp.FragmentConfiguration;
import org.eclipse.jetty.webapp.MetaInfConfiguration;
import org.eclipse.jetty.webapp.TagLibConfiguration;
import org.eclipse.jetty.webapp.WebAppContext;
import org.eclipse.jetty.webapp.WebInfConfiguration;
import org.eclipse.jetty.webapp.WebXmlConfiguration;
public class EmbedMe {
public static void main(String[] args) throws Exception {
int port = 8080;
Server server = new Server(port);
String wardir = "target/sample-webapp-1-SNAPSHOT";
WebAppContext context = new WebAppContext();
// This can be your own project's jar file, but the contents should
// conform to the WAR layout.
context.setResourceBase(wardir);
// A WEB-INF/web.xml is required for Servlet 3.0
context.setDescriptor(wardir + "WEB-INF/web.xml");
// Initialize the various configurations required to auto-wire up
// the Servlet 3.0 annotations, descriptors, and fragments
context.setConfigurations(new Configuration[] {
new AnnotationConfiguration(),
new WebXmlConfiguration(),
new WebInfConfiguration(),
new TagLibConfiguration(),
new PlusConfiguration(),
new MetaInfConfiguration(),
new FragmentConfiguration(),
new EnvConfiguration() });
// Specify the context path that you want this webapp to show up as
context.setContextPath("/");
// Tell the classloader to use the "server" classpath over the
// webapp classpath. (this is so that jars and libs in your
// server classpath are used, requiring no WEB-INF/lib
// directory to exist)
context.setParentLoaderPriority(true);
// Add this webapp to the server
server.setHandler(context);
// Start the server thread
server.start();
// Wait for the server thread to stop (optional)
server.join();
}
}