public class JettyServletWebServerFactory extends AbstractServletWebServerFactory implements ResourceLoaderAware
ServletWebServerFactory
that can be used to create a JettyWebServer
.
Can be initialized using Spring's ServletContextInitializer
s or Jetty
Configuration
s.
Unless explicitly configured otherwise this factory will created servers that listens for HTTP requests on port 8080.
AbstractConfigurableWebServerFactory.setPort(int)
,
setConfigurations(Collection)
,
JettyWebServer
logger
Constructor and Description |
---|
JettyServletWebServerFactory()
Create a new
JettyServletWebServerFactory instance. |
JettyServletWebServerFactory(int port)
Create a new
JettyServletWebServerFactory that listens for requests using
the specified port. |
JettyServletWebServerFactory(String contextPath,
int port)
Create a new
JettyServletWebServerFactory with the specified context path
and port. |
Modifier and Type | Method and Description |
---|---|
void |
addConfigurations(Configuration... configurations)
Add
Configuration s that will be applied to the WebAppContext before
the server is started. |
protected void |
addDefaultServlet(WebAppContext context)
Add Jetty's
DefaultServlet to the given WebAppContext . |
protected void |
addJspServlet(WebAppContext context)
Add Jetty's
JspServlet to the given WebAppContext . |
void |
addServerCustomizers(JettyServerCustomizer... customizers)
Add
JettyServerCustomizer s that will be applied to the Server
before it is started. |
protected void |
configureSsl(SslContextFactory factory,
Ssl ssl)
Configure the SSL connection.
|
protected void |
configureWebAppContext(WebAppContext context,
ServletContextInitializer... initializers)
Configure the given Jetty
WebAppContext for use. |
Collection<Configuration> |
getConfigurations()
Returns a mutable collection of Jetty
Configuration s that will be applied
to the WebAppContext before the server is created. |
protected JettyWebServer |
getJettyWebServer(Server server)
Factory method called to create the
JettyWebServer . |
Collection<JettyServerCustomizer> |
getServerCustomizers()
Returns a mutable collection of Jetty
JettyServerCustomizer s that will be
applied to the Server before the it is created. |
protected Configuration |
getServletContextInitializerConfiguration(WebAppContext webAppContext,
ServletContextInitializer... initializers)
Return a Jetty
Configuration that will invoke the specified
ServletContextInitializer s. |
ThreadPool |
getThreadPool()
Returns a Jetty
ThreadPool that should be used by the Server . |
protected Configuration[] |
getWebAppContextConfigurations(WebAppContext webAppContext,
ServletContextInitializer... initializers)
Return the Jetty
Configuration s that should be applied to the server. |
WebServer |
getWebServer(ServletContextInitializer... initializers)
Gets a new fully configured but paused
WebServer instance. |
protected void |
postProcessWebAppContext(WebAppContext webAppContext)
Post process the Jetty
WebAppContext before it used with the Jetty Server. |
void |
setAcceptors(int acceptors)
Set the number of acceptor threads to use.
|
void |
setConfigurations(Collection<? extends Configuration> configurations)
Sets Jetty
Configuration s that will be applied to the WebAppContext
before the server is created. |
void |
setResourceLoader(ResourceLoader resourceLoader) |
void |
setSelectors(int selectors)
Set the number of selector threads to use.
|
void |
setServerCustomizers(Collection<? extends JettyServerCustomizer> customizers)
Sets
JettyServerCustomizer s that will be applied to the Server
before it is started. |
void |
setThreadPool(ThreadPool threadPool)
Set a Jetty
ThreadPool that should be used by the Server . |
void |
setUseForwardHeaders(boolean useForwardHeaders)
Set if x-forward-* headers should be processed.
|
addInitializers, getContextPath, getDisplayName, getDocumentRoot, getJsp, getLocaleCharsetMappings, getMimeMappings, getSessionStoreDir, getSessionTimeout, getUrlsOfJarsWithMetaInfResources, getValidDocumentRoot, getValidSessionStoreDir, getValidSessionStoreDir, isPersistSession, isRegisterDefaultServlet, mergeInitializers, setContextPath, setDisplayName, setDocumentRoot, setInitializers, setJsp, setLocaleCharsetMappings, setMimeMappings, setPersistSession, setRegisterDefaultServlet, setSessionStoreDir, setSessionTimeout, setSessionTimeout, shouldRegisterJspServlet
addErrorPages, createTempDir, getAddress, getCompression, getErrorPages, getPort, getServerHeader, getSsl, getSslStoreProvider, setAddress, setCompression, setErrorPages, setPort, setServerHeader, setSsl, setSslStoreProvider
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
setAddress, setCompression, setErrorPages, setPort, setServerHeader, setSsl, setSslStoreProvider
addErrorPages
public JettyServletWebServerFactory()
JettyServletWebServerFactory
instance.public JettyServletWebServerFactory(int port)
JettyServletWebServerFactory
that listens for requests using
the specified port.port
- the port to listen onpublic JettyServletWebServerFactory(String contextPath, int port)
JettyServletWebServerFactory
with the specified context path
and port.contextPath
- the root context pathport
- the port to listen onpublic WebServer getWebServer(ServletContextInitializer... initializers)
ServletWebServerFactory
WebServer
instance. Clients should
not be able to connect to the returned server until WebServer.start()
is
called (which happens when the ApplicationContext
has been fully
refreshed).getWebServer
in interface ServletWebServerFactory
initializers
- ServletContextInitializer
s that should be applied as
the server startsWebServer
WebServer.stop()
protected void configureSsl(SslContextFactory factory, Ssl ssl)
factory
- the Jetty SslContextFactory
.ssl
- the ssl details.protected final void configureWebAppContext(WebAppContext context, ServletContextInitializer... initializers)
WebAppContext
for use.context
- the context to configureinitializers
- the set of initializers to applyprotected final void addDefaultServlet(WebAppContext context)
DefaultServlet
to the given WebAppContext
.context
- the jetty WebAppContext
protected final void addJspServlet(WebAppContext context)
JspServlet
to the given WebAppContext
.context
- the jetty WebAppContext
protected Configuration[] getWebAppContextConfigurations(WebAppContext webAppContext, ServletContextInitializer... initializers)
Configuration
s that should be applied to the server.webAppContext
- the Jetty WebAppContext
initializers
- the ServletContextInitializer
s to applyprotected Configuration getServletContextInitializerConfiguration(WebAppContext webAppContext, ServletContextInitializer... initializers)
Configuration
that will invoke the specified
ServletContextInitializer
s. By default this method will return a
ServletContextInitializerConfiguration
.webAppContext
- the Jetty WebAppContext
initializers
- the ServletContextInitializer
s to applyConfiguration
instanceprotected void postProcessWebAppContext(WebAppContext webAppContext)
WebAppContext
before it used with the Jetty Server.
Subclasses can override this method to apply additional processing to the
WebAppContext
.webAppContext
- the Jetty WebAppContext
protected JettyWebServer getJettyWebServer(Server server)
JettyWebServer
. Subclasses can
override this method to return a different JettyWebServer
or apply
additional processing to the Jetty server.server
- the Jetty server.JettyWebServer
instancepublic void setResourceLoader(ResourceLoader resourceLoader)
setResourceLoader
in interface ResourceLoaderAware
public void setUseForwardHeaders(boolean useForwardHeaders)
useForwardHeaders
- if x-forward headers should be usedpublic void setAcceptors(int acceptors)
acceptors
- the number of acceptor threads to usepublic void setSelectors(int selectors)
selectors
- the number of selector threads to usepublic void setServerCustomizers(Collection<? extends JettyServerCustomizer> customizers)
JettyServerCustomizer
s that will be applied to the Server
before it is started. Calling this method will replace any existing customizers.customizers
- the Jetty customizers to applypublic Collection<JettyServerCustomizer> getServerCustomizers()
JettyServerCustomizer
s that will be
applied to the Server
before the it is created.JettyServerCustomizer
spublic void addServerCustomizers(JettyServerCustomizer... customizers)
JettyServerCustomizer
s that will be applied to the Server
before it is started.customizers
- the customizers to addpublic void setConfigurations(Collection<? extends Configuration> configurations)
Configuration
s that will be applied to the WebAppContext
before the server is created. Calling this method will replace any existing
configurations.configurations
- the Jetty configurations to applypublic Collection<Configuration> getConfigurations()
Configuration
s that will be applied
to the WebAppContext
before the server is created.Configuration
spublic void addConfigurations(Configuration... configurations)
Configuration
s that will be applied to the WebAppContext
before
the server is started.configurations
- the configurations to addpublic ThreadPool getThreadPool()
ThreadPool
that should be used by the Server
.ThreadPool
or null
public void setThreadPool(ThreadPool threadPool)
ThreadPool
that should be used by the Server
. If set to
null
(default), the Server
creates a ThreadPool
implicitly.threadPool
- a Jetty ThreadPool to be usedCopyright © 2017 Pivotal Software, Inc.. All rights reserved.