Merge pull request #5740 from eclipse/jetty-10.0.x-5739-Remove-distribution-from-doco
Fix #5739 Remove distribution from doco
This commit is contained in:
commit
0a034dbd50
|
@ -34,7 +34,7 @@ To build, use:
|
|||
mvn clean install
|
||||
```
|
||||
|
||||
The Jetty distribution will be built in `jetty-distribution/target/distribution`.
|
||||
Eclipse Jetty will be built in `jetty-home/target/jetty-home`.
|
||||
|
||||
The first build may take a longer than expected as Maven downloads all the dependencies.
|
||||
|
||||
|
|
|
@ -42,7 +42,7 @@ public class OneWebAppTest extends AbstractEmbeddedTest
|
|||
@BeforeEach
|
||||
public void startServer() throws Exception
|
||||
{
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-distribution not found");
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-home not found");
|
||||
|
||||
server = OneWebApp.createServer(0);
|
||||
server.start();
|
||||
|
|
|
@ -42,7 +42,7 @@ public class OneWebAppWithJspTest extends AbstractEmbeddedTest
|
|||
@BeforeEach
|
||||
public void startServer() throws Exception
|
||||
{
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-distribution not found");
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-home not found");
|
||||
|
||||
server = OneWebAppWithJsp.createServer(0);
|
||||
server.start();
|
||||
|
|
|
@ -41,7 +41,7 @@ public class ServerWithAnnotationsTest extends AbstractEmbeddedTest
|
|||
@BeforeEach
|
||||
public void startServer() throws Exception
|
||||
{
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-distribution not found");
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-home not found");
|
||||
|
||||
server = ServerWithAnnotations.createServer(0);
|
||||
server.start();
|
||||
|
|
|
@ -42,7 +42,7 @@ public class ServerWithJNDITest extends AbstractEmbeddedTest
|
|||
@BeforeEach
|
||||
public void startServer() throws Exception
|
||||
{
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-distribution not found");
|
||||
assumeTrue(JettyHome.JETTY_HOME != null, "jetty-home not found");
|
||||
|
||||
server = ServerWithJNDI.createServer(0);
|
||||
server.start();
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<!-- =======================================================================================-->
|
||||
<!-- Build file for running the test-jetty-webapp from the jetty distro. -->
|
||||
<!-- -->
|
||||
<!-- You will need to have a full jetty-distribution available unpacked on your local file -->
|
||||
<!-- You will need to have a full jetty-home available unpacked on your local file -->
|
||||
<!-- system. We will refer to the top level directory of this distribution as $JETTY_HOME. -->
|
||||
<!-- -->
|
||||
<!-- To use: -->
|
||||
|
|
|
@ -216,8 +216,8 @@ At this point the server has been configured with connectors for both HTTP and H
|
|||
2017-08-31 10:19:58.855:INFO::main: Logging initialized @372ms to org.eclipse.jetty.util.log.StdErrLog
|
||||
2017-08-31 10:19:59.076:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
2017-08-31 10:19:59.125:INFO:oejs.AbstractConnector:main: Started ServerConnector@421e98e0{HTTP/1.1,[http/1.1]}{0.0.0.0:8080}
|
||||
2017-08-31 10:19:59.150:INFO:oejus.SslContextFactory:main: x509=X509@5315b42e(jetty,h=[jetty.eclipse.org],w=[]) for SslContextFactory@2ef9b8bc(file:///Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase/etc/keystore,file:///Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase/etc/keystore)
|
||||
2017-08-31 10:19:59.151:INFO:oejus.SslContextFactory:main: x509=X509@5d624da6(mykey,h=[],w=[]) for SslContextFactory@2ef9b8bc(file:///Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase/etc/keystore,file:///Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase/etc/keystore)
|
||||
2017-08-31 10:19:59.150:INFO:oejus.SslContextFactory:main: x509=X509@5315b42e(jetty,h=[jetty.eclipse.org],w=[]) for SslContextFactory@2ef9b8bc(file:///var/my-jetty-base/etc/keystore,file:///var/my-jetty-base/etc/keystore)
|
||||
2017-08-31 10:19:59.151:INFO:oejus.SslContextFactory:main: x509=X509@5d624da6(mykey,h=[],w=[]) for SslContextFactory@2ef9b8bc(file:///var/my-jetty-base/etc/keystore,file:///var/my-jetty-base/etc/keystore)
|
||||
2017-08-31 10:19:59.273:INFO:oejs.AbstractConnector:main: Started ServerConnector@2b98378d{SSL,[ssl, http/1.1]}{0.0.0.0:8443}
|
||||
2017-08-31 10:19:59.274:INFO:oejs.Server:main: Started @791ms
|
||||
....
|
||||
|
|
|
@ -26,7 +26,7 @@ To test a Jetty release, complete the following steps for each release you want
|
|||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
||||
wget https://oss.sonatype.org/content/repositories/jetty-[reponumber]/org/eclipse/jetty/jetty-distribution/[jetty-version]/jetty-distribution-9.[jetty-minor-version].tar.gz
|
||||
wget https://oss.sonatype.org/content/repositories/jetty-[reponumber]/org/eclipse/jetty/jetty-home/[jetty-version]/jetty-home-9.[jetty-minor-version].tar.gz
|
||||
|
||||
|
||||
....
|
||||
|
@ -200,12 +200,12 @@ Thread Pool - Concurrent Threads max = 239 | Queue Size max = 1002 | Queue Laten
|
|||
|
||||
|
||||
....
|
||||
7. Deploy `cometd.war` to the `webapps` directory of the jetty-distribution tested above.
|
||||
7. Deploy `cometd.war` to the `webapps` directory of the jetty-home tested above.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
||||
cp cometd-demo/target/cometd-demo-[version].war [pathToJetty]/jetty-distribution-[jetty-version]/webapps/
|
||||
cp cometd-demo/target/cometd-demo-[version].war [pathToJetty]/jetty-home-[jetty-version]/webapps/
|
||||
|
||||
|
||||
....
|
||||
|
|
|
@ -36,7 +36,7 @@ image:debug-eclipse-1.png[image,width=576]
|
|||
+
|
||||
image:debug-eclipse-2.png[image,width=576]
|
||||
|
||||
3. Accessing that servlet within your browser, pointed at your remote debug configurated jetty-distribution, should transition your Eclipse instance to the standard Debug view.
|
||||
3. Accessing that servlet within your browser, pointed at your remote debug configurated jetty-home, should transition your Eclipse instance to the standard Debug view.
|
||||
+
|
||||
image:debug-eclipse-3.png[image,width=576]
|
||||
|
||||
|
|
|
@ -39,7 +39,7 @@ The red dot and red background on the line mark the breakpoint.
|
|||
+
|
||||
image:intellij_set_breakpoint.png[image,width=800]
|
||||
|
||||
3. Accessing that servlet within your browser, pointed at your remote debug configured jetty-distribution, should transition your IntelliJ instance to the standard debugger view.
|
||||
3. Accessing that servlet within your browser, pointed at your remote debug configured jetty-home, should transition your IntelliJ instance to the standard debugger view.
|
||||
+
|
||||
image:intellij_debug_view.png[image,width=800]
|
||||
|
||||
|
|
|
@ -28,7 +28,7 @@ This is easily accomplished.
|
|||
|
||||
____
|
||||
[NOTE]
|
||||
This example assumes you are deploying your web application into the jetty-distribution.
|
||||
This example assumes you are deploying your web application into a jetty-base.
|
||||
____
|
||||
|
||||
===== Starting Jetty
|
||||
|
@ -47,7 +47,7 @@ $ java -Xdebug -agentlib:jdwp=transport=dt_socket,address=9999,server=y,suspend=
|
|||
....
|
||||
|
||||
Via `start.ini`::
|
||||
This approach is best used if you want to debug a particular jetty-distribution and not have to remember the commandline incantations.
|
||||
This approach is best used if you want to debug a particular jetty-base and not have to remember the commandline incantations.
|
||||
+
|
||||
1. Edit the `start.ini` and uncomment the --exec line, this is required if you are adding jvm options to the start.ini file as jetty-start must generate the classpath required and fork a new jvm.
|
||||
2. Add the parameters mentioned above in the Command Line option so your start.ini looks like this:
|
||||
|
@ -84,7 +84,7 @@ Via `start.ini`::
|
|||
+
|
||||
Uncomment any other jvm environmental options you so desire for your debugging session.
|
||||
|
||||
3. Regardless of the option chosen, you should see the following lines at the top of your jetty-distribution startup.
|
||||
3. Regardless of the option chosen, you should see the following lines at the top of your jetty startup.
|
||||
+
|
||||
[source, plain, subs="{sub-order}"]
|
||||
----
|
||||
|
|
|
@ -48,7 +48,7 @@ Here's an example of the log output from Jetty when one of the sample Metro wars
|
|||
[2093] java -jar start.jar
|
||||
|
||||
2013-07-26 15:47:53.480:INFO:oejs.Server:main: jetty-9.0.4.v20130625
|
||||
2013-07-26 15:47:53.549:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/home/user/jetty-distribution-{VERSION}/webapps/] at interval 1
|
||||
2013-07-26 15:47:53.549:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/home/user/jetty-home-{VERSION}/webapps/] at interval 1
|
||||
Jul 26, 2013 3:47:53 PM com.sun.xml.ws.transport.http.servlet.WSServletContextListener contextInitialized
|
||||
INFO: WSSERVLET12: JAX-WS context listener initializing
|
||||
Jul 26, 2013 3:47:56 PM com.sun.xml.ws.server.MonitorBase createRoot
|
||||
|
|
|
@ -147,7 +147,7 @@ etc/jetty.xml,etc/jetty-http.xml,etc/jetty-deployer.xml
|
|||
Note that the paths can either be relative or absolute, or a mixture.
|
||||
If the path is relative, it is resolved against either *jetty.home* or **jetty.home.bundle**, whichever was specified.
|
||||
You can use this ability to mix and match jetty configuration files to add functionality, such as adding in a https connector.
|
||||
Here's an example of adding a HTTPS connector, using the relevant files from the jetty-distribution:
|
||||
Here's an example of adding a HTTPS connector, using the relevant files from the jetty-home:
|
||||
+
|
||||
....
|
||||
etc/jetty.xml, etc/jetty-http.xml, /opt/jetty/etc/jetty-ssl.xml, /opt/jetty/etc/jetty-https.xml, etc/jetty-deployer.xml
|
||||
|
|
|
@ -28,7 +28,7 @@ https://www.eclipse.org/jetty/download.html
|
|||
____
|
||||
|
||||
It is available in both zip and gzip formats; download the one most appropriate for your system.
|
||||
When you download and unpack the binary, it is extracted into a directory called `jetty-distribution-VERSION.`
|
||||
When you download and unpack the binary, it is extracted into a directory called `jetty-home-VERSION.`
|
||||
Put this directory in a convenient location.
|
||||
The rest of the instructions in this documentation refer to this location as either `$JETTY_HOME` or as `$(jetty.home).`
|
||||
|
||||
|
|
|
@ -490,5 +490,5 @@ After enabling `console-capture`, the output is as follows, which displays the l
|
|||
....
|
||||
[my-base]$ java -jar /path/to/jetty-home/start.jar
|
||||
151 [main] INFO org.eclipse.jetty.util.log - Logging initialized @238ms to org.eclipse.jetty.util.log.Slf4jLog
|
||||
196 [main] INFO org.eclipse.jetty.util.log - Console stderr/stdout captured to /installs/jetty-distribution/mybase/logs/2016_10_21.jetty.log
|
||||
196 [main] INFO org.eclipse.jetty.util.log - Console stderr/stdout captured to /installs/my-jetty-base/logs/2016_10_21.jetty.log
|
||||
....
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -51,7 +51,7 @@ INFO: resources enabled in ${jetty.base}/start.ini
|
|||
The replacement `logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory.
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement `logging.mod` and puts it into the `${jetty.base}/modules/` directory for use by mybase only.
|
||||
. The `start.jar --add-to-start=logging` command performs a number of steps to make the logging module available to the `${jetty.base}` configuration.
|
||||
.. The `--module=logging` command is added to the `${jetty.base}/start.ini` configuration.
|
||||
|
|
|
@ -59,7 +59,7 @@ INFO: resources enabled in ${jetty.base}/${jetty.base}
|
|||
The replacement `logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory.
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement `logging.mod` and puts it into the `${jetty.base}/modules/` directory for use by `mybase` only.
|
||||
. The `start.jar --add-to-start=logging` command performs a number of steps to make the logging module available to the `${jetty.base}`
|
||||
configuration.
|
||||
|
|
|
@ -53,7 +53,7 @@ INFO: resources enabled in ${jetty.base}/start.ini
|
|||
The replacement `logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement `logging.mod` and puts it into the `${jetty.base}/modules/` directory for use by `mybase` only.
|
||||
. The `start.jar --add-to-start=logging` command performs a number of steps to make the logging module available to the `${jetty.base}` configuration.
|
||||
.. The `--module=logging` command is added to the `${jetty.base}/start.ini` configuration.
|
||||
|
|
|
@ -119,7 +119,7 @@ $
|
|||
This replacement `centralized-webapp-logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory.
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement config overlay for the `${jetty.base}/modules/` directory to use.
|
||||
. The `start.jar --add-to-start=centralized-webapp-logging` command performs a number of steps to make the centralized-webapp-logging module available to the `${jetty.base}` configuration.
|
||||
.. A new `${jetty.base}/start.d/centralized-webapp-logging.ini` configuration was created.
|
||||
|
|
|
@ -49,7 +49,7 @@ DOWNLOAD: https://raw.githubusercontent.com/jetty-project/logging-modules/master
|
|||
The replacement `logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory.
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement `logging.mod` and puts it into the `${jetty.base}/modules/` directory for use by `mybase` only.
|
||||
. The `start.jar --add-to-start=logging` command performs a number of steps to make the logging module available to the `${jetty.base}` configuration.
|
||||
.. The `--module=logging` command is added to the `${jetty.base}/start.ini` configuration.
|
||||
|
|
|
@ -120,7 +120,7 @@ INFO: resources enabled in ${jetty.base}/start.ini
|
|||
The replacement `logging.mod` performs a number of tasks.
|
||||
|
||||
. `mybase` is a `${jetty.base}` directory.
|
||||
. The jetty-distribution is unpacked (and untouched) into `/opt/jetty-dist/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The jetty-home is unpacked (and untouched) into `/opt/jetty-home/` and becomes the `${jetty.home}` directory for this demonstration.
|
||||
. The `curl` command downloads the replacement `logging.mod` and puts it into the `${jetty.base}/modules/` directory for use by `mybase` only.
|
||||
. The `start.jar --add-to-start=logging` command performs a number of steps to make the logging module available to the `${jetty.base}` configuration.
|
||||
.. The `--module=logging` command is added to the `${jetty.base}/start.ini` configuration.
|
||||
|
|
|
@ -108,8 +108,8 @@ Installing jetty-buildpack.git.
|
|||
Downloading JDK...
|
||||
Copying openjdk-1.7.0_21.tar.gz from the buildpack cache ...
|
||||
Unpacking JDK to .jdk
|
||||
Downloading Jetty: jetty-distribution-{VERSION}.tar.gz
|
||||
Downloading jetty-distribution-{VERSION}.tar.gz from http://repo2.maven.org/maven2/org/eclipse/jetty/jetty-distribution/9.0.3.v20130506/ ...
|
||||
Downloading Jetty: jetty-home-{VERSION}.tar.gz
|
||||
Downloading jetty-home-{VERSION}.tar.gz from http://repo2.maven.org/maven2/org/eclipse/jetty/jetty-home/10.0.0.v202012xx/ ...
|
||||
Unpacking Jetty to .jetty
|
||||
-> Uploading staged droplet (36M)
|
||||
-> Uploaded droplet
|
||||
|
|
|
@ -48,7 +48,7 @@ This page describes how to configure SSL in Jetty with modules.
|
|||
It provides an example of using the `${jetty.home}` and `${jetty.base}` to maximum effect.
|
||||
It also includes a detailed explanation of how modules work.
|
||||
|
||||
This example assumes you have the jetty-distribution unpacked in `/home/user/jetty-distribution-{VERSION}`.
|
||||
This example assumes you have the jetty-home unpacked in `/home/user/jetty-home-{VERSION}`.
|
||||
It also assumes you are using `start.ini` to configure your server features.
|
||||
|
||||
1. Create a base directory anywhere.
|
||||
|
@ -177,7 +177,7 @@ Java Environment:
|
|||
|
||||
Jetty Environment:
|
||||
-----------------
|
||||
jetty.home=/home/user/jetty-distribution-{VERSION}
|
||||
jetty.home=/home/user/jetty-home-{VERSION}
|
||||
jetty.base=/home/user/my-base
|
||||
jetty.version={VERSION}
|
||||
|
||||
|
@ -188,7 +188,7 @@ JVM Arguments:
|
|||
System Properties:
|
||||
------------------
|
||||
jetty.base = /home/user/my-base
|
||||
jetty.home = /home/user/jetty-distribution-{VERSION}
|
||||
jetty.home = /home/user/jetty-home-{VERSION}
|
||||
|
||||
Properties:
|
||||
-----------
|
||||
|
@ -448,7 +448,7 @@ If you want to start using a new module:
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[my-base] $ java -jar ../jetty-distribution-{VERSION}/start.jar --add-to-start=https
|
||||
[my-base] $ java -jar ../jetty-home-{VERSION}/start.jar --add-to-start=https
|
||||
....
|
||||
|
||||
This adds the `--module=` lines and associated properties (the parameterized values mentioned above), to your `start.ini`.
|
||||
|
@ -477,7 +477,7 @@ For more information on the `start.jar` in 9.1, see xref:start-jar[].
|
|||
[[summary-configuring-SSL-Jetty]]
|
||||
==== Summary of Configuring SSL
|
||||
|
||||
1. Download and unpack Jetty into `/home/user/jetty-distribution-{VERSION}`.
|
||||
1. Download and unpack Jetty into `/home/user/jetty-home-{VERSION}`.
|
||||
2. Go to your base directory and just use the distribution, no editing.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
|
@ -506,7 +506,7 @@ You can see what the configuration looks like, after all of the modules are reso
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[my-base] $ java -jar ../jetty-distribution-{VERSION}/start.jar --list-config
|
||||
[my-base] $ java -jar ../jetty-home-{VERSION}/start.jar --list-config
|
||||
....
|
||||
|
||||
Just because the JARs exist on disk does not mean that they are in use.
|
||||
|
|
|
@ -30,7 +30,7 @@ Java Environment:
|
|||
java.runtime.name = Java(TM) SE Runtime Environment
|
||||
java.runtime.version = 1.8.0_92-b14
|
||||
java.io.tmpdir = /var/folders/h6/yb_lbnnn11g0y1jjlvqg631h0000gn/T/
|
||||
user.dir = /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
user.dir = /var/my-jetty-base
|
||||
user.language = en
|
||||
user.country = US
|
||||
|
||||
|
@ -38,14 +38,14 @@ Jetty Environment:
|
|||
-----------------
|
||||
jetty.version = {VERSION}
|
||||
jetty.tag.version = master
|
||||
jetty.home = /Users/staff/installs/repository/jetty-distribution-{VERSION}
|
||||
jetty.base = /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
jetty.home = /Users/staff/installs/repository/jetty-home-{VERSION}
|
||||
jetty.base = /var/my-jetty-base
|
||||
|
||||
Config Search Order:
|
||||
--------------------
|
||||
<command-line>
|
||||
${jetty.base} -> /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
${jetty.home} -> /Users/staff/installs/repository/jetty-distribution-{VERSION}
|
||||
${jetty.base} -> /var/my-jetty-base
|
||||
${jetty.home} -> /Users/staff/installs/repository/jetty-home-{VERSION}
|
||||
|
||||
|
||||
JVM Arguments:
|
||||
|
|
|
@ -30,7 +30,7 @@ Java Environment:
|
|||
java.runtime.name = Java(TM) SE Runtime Environment
|
||||
java.runtime.version = 1.8.0_92-b14
|
||||
java.io.tmpdir = /var/folders/h6/yb_lbnnn11g0y1jjlvqg631h0000gn/T/
|
||||
user.dir = /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
user.dir = /var/my-jetty-base
|
||||
user.language = en
|
||||
user.country = US
|
||||
|
||||
|
@ -38,14 +38,14 @@ Jetty Environment:
|
|||
-----------------
|
||||
jetty.version = {VERSION}
|
||||
jetty.tag.version = master
|
||||
jetty.home = /Users/staff/installs/repository/jetty-distribution-{VERSION}
|
||||
jetty.base = /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
jetty.home = /Users/staff/installs/repository/jetty-home-{VERSION}
|
||||
jetty.base = /var/my-jetty-base
|
||||
|
||||
Config Search Order:
|
||||
--------------------
|
||||
<command-line>
|
||||
${jetty.base} -> /Users/staff/installs/repository/jetty-distribution-{VERSION}/mybase
|
||||
${jetty.home} -> /Users/staff/installs/repository/jetty-distribution-{VERSION}
|
||||
${jetty.base} -> /var/my-jetty-base
|
||||
${jetty.home} -> /Users/staff/installs/repository/jetty-home-{VERSION}
|
||||
|
||||
|
||||
JVM Arguments:
|
||||
|
|
|
@ -57,7 +57,7 @@ The Jetty Distribution comes with an example `${jetty.base}` which enables the v
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ ls -la
|
||||
[jetty-home-{VERSION}]$ ls -la
|
||||
|
||||
total 496
|
||||
drwxrwxr-x 11 user group 4096 Oct 8 15:23 ./
|
||||
|
@ -78,12 +78,12 @@ drwxrwxr-x 2 user group 4096 Oct 8 06:54 start.d/
|
|||
-rw-rw-r-- 1 user group 336468 Sep 30 19:55 VERSION.txt
|
||||
drwxrwxr-x 2 user group 4096 Oct 8 06:54 webapps/
|
||||
|
||||
[jetty-distribution-{VERSION}]$ cd demo-base
|
||||
[jetty-home-{VERSION}]$ cd demo-base
|
||||
[my-base]$ java -jar /path/to/jetty-home/start.jar
|
||||
|
||||
2013-10-16 09:08:47.800:WARN::main: demo test-realm is deployed. DO NOT USE IN PRODUCTION!
|
||||
2013-10-16 09:08:47.802:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
2013-10-16 09:08:47.817:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/home/user/jetty-distribution-{VERSION}/demo-base/webapps/] at interval 1
|
||||
2013-10-16 09:08:47.817:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/home/user/jetty-home-{VERSION}/demo-base/webapps/] at interval 1
|
||||
2013-10-16 09:08:48.072:WARN::main: async-rest webapp is deployed. DO NOT USE IN PRODUCTION!
|
||||
...
|
||||
....
|
||||
|
@ -104,22 +104,22 @@ Java Environment:
|
|||
java.runtime.name = Java(TM) SE Runtime Environment
|
||||
java.runtime.version = 1.8.0_92-b14
|
||||
java.io.tmpdir = /var/folders/h6/yb_lbnnn11g0y1jjlvqg631h0000gn/T/
|
||||
user.dir = /home/user/jetty-distribution-{VERSION}
|
||||
user.dir = /home/user/jetty-home-{VERSION}
|
||||
user.language = en
|
||||
user.country = US
|
||||
|
||||
Jetty Environment:
|
||||
-----------------
|
||||
jetty.home=/home/user/jetty-distribution-{VERSION}
|
||||
jetty.home=/home/user/jetty-home-{VERSION}
|
||||
jetty.tag.version = master
|
||||
jetty.base=/home/user/jetty-distribution-{VERSION}/demo-base
|
||||
jetty.base=/home/user/jetty-home-{VERSION}/demo-base
|
||||
jetty.version={VERSION}
|
||||
|
||||
Config Search Order:
|
||||
--------------------
|
||||
<command-line>
|
||||
${jetty.base} -> /home/user/jetty-distribution-{VERSION}/demo-base
|
||||
${jetty.home} -> /home/user/Desktop/jetty-distribution-{VERSION}
|
||||
${jetty.base} -> /home/user/jetty-home-{VERSION}/demo-base
|
||||
${jetty.home} -> /home/user/Desktop/jetty-home-{VERSION}
|
||||
|
||||
JVM Arguments:
|
||||
--------------
|
||||
|
@ -127,8 +127,8 @@ JVM Arguments:
|
|||
|
||||
System Properties:
|
||||
------------------
|
||||
jetty.base = /home/user/jetty-distribution-{VERSION}/demo-base
|
||||
jetty.home = /home/user/jetty-distribution-{VERSION}
|
||||
jetty.base = /home/user/jetty-home-{VERSION}/demo-base
|
||||
jetty.home = /home/user/jetty-home-{VERSION}
|
||||
|
||||
Properties:
|
||||
-----------
|
||||
|
@ -275,11 +275,11 @@ You can opt to manually define the `${jetty.home}` and `${jetty.base}` directori
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ pwd
|
||||
/home/user/jetty-distribution-{VERSION}
|
||||
[jetty-home-{VERSION}]$ pwd
|
||||
/home/user/jetty-home-{VERSION}
|
||||
|
||||
[jetty-distribution-{VERSION}]$ java -jar start.jar \
|
||||
jetty.home=/home/user/jetty-distribution-{VERSION} \
|
||||
[jetty-home-{VERSION}]$ java -jar start.jar \
|
||||
jetty.home=/home/user/jetty-home-{VERSION} \
|
||||
jetty.base=/home/user/my-base
|
||||
|
||||
2013-10-16 09:08:47.802:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
|
@ -293,10 +293,10 @@ The following example uses default discovery of `${jetty.home}` by using the par
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ pwd
|
||||
/home/user/jetty-distribution-{VERSION}
|
||||
[jetty-home-{VERSION}]$ pwd
|
||||
/home/user/jetty-home-{VERSION}
|
||||
|
||||
[jetty-distribution-{VERSION}]$ java -jar start.jar jetty.base=/home/user/my-base
|
||||
[jetty-home-{VERSION}]$ java -jar start.jar jetty.base=/home/user/my-base
|
||||
|
||||
2013-10-16 09:08:47.802:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
2013-10-16 09:08:47.817:INFO:oejdp.ScanningAppProvider:main: Deployment monitor [file:/home/user/my-base/webapps/] at interval 1
|
||||
|
@ -310,10 +310,10 @@ The following demonstrates this by allowing default discovery of `${jetty.home}`
|
|||
|
||||
[source,screen,subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ pwd
|
||||
/home/user/jetty-distribution-{VERSION}
|
||||
[jetty-home-{VERSION}]$ pwd
|
||||
/home/user/jetty-home-{VERSION}
|
||||
|
||||
[jetty-distribution-{VERSION}]$ cd /home/user/my-base
|
||||
[jetty-home-{VERSION}]$ cd /home/user/my-base
|
||||
[my-base]$ java -jar /path/to/jetty-home/start.jar
|
||||
|
||||
2013-10-16 09:08:47.802:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
|
|
|
@ -73,8 +73,8 @@ The simplest way to start Jetty is via the `start.jar` mechanism using the follo
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[user]$ cd jetty-distribution-{VERSION}
|
||||
[jetty-distribution-{VERSION}]$ java -jar start.jar --module=http jetty.http.port=8080
|
||||
[user]$ cd jetty-home-{VERSION}
|
||||
[jetty-home-{VERSION}]$ java -jar start.jar --module=http jetty.http.port=8080
|
||||
....
|
||||
|
||||
This command uses the `start.jar` mechanism to bootstrap the classpath, properties, and XML files with the metadata obtained from the `http` module.
|
||||
|
@ -82,7 +82,7 @@ Specifically the `http` module is defined in the `${jetty.home}/modules/http.mod
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ cat modules/http.mod
|
||||
[jetty-home-{VERSION}]$ cat modules/http.mod
|
||||
[depend]
|
||||
server
|
||||
|
||||
|
@ -101,7 +101,7 @@ Following the server dependency, the `${jetty.home}/modules/server.mod` file inc
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ cat modules/server.mod
|
||||
[jetty-home-{VERSION}]$ cat modules/server.mod
|
||||
[lib]
|
||||
lib/jetty-servlet-api-4.0.2.jar
|
||||
lib/jetty-http-${jetty.version}.jar
|
||||
|
@ -125,7 +125,7 @@ Another way to see this is by asking Jetty what its configuration looks like by
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[jetty-distribution-{VERSION}]$ java -jar start.jar --module=http jetty.http.port=9099 --list-config
|
||||
[jetty-home-{VERSION}]$ java -jar start.jar --module=http jetty.http.port=9099 --list-config
|
||||
|
||||
Java Environment:
|
||||
-----------------
|
||||
|
@ -140,8 +140,8 @@ Java Environment:
|
|||
|
||||
Jetty Environment:
|
||||
-----------------
|
||||
jetty.home=/opt/jetty/jetty-distribution-{VERSION}
|
||||
jetty.base=/opt/jetty/jetty-distribution-{VERSION}
|
||||
jetty.home=/opt/jetty/jetty-home-{VERSION}
|
||||
jetty.base=/opt/jetty/jetty-home-{VERSION}
|
||||
jetty.version={VERSION}
|
||||
|
||||
JVM Arguments:
|
||||
|
@ -150,8 +150,8 @@ JVM Arguments:
|
|||
|
||||
System Properties:
|
||||
------------------
|
||||
jetty.home = /opt/jetty/jetty-distribution-{VERSION}
|
||||
jetty.base = /opt/jetty/jetty-distribution-{VERSION}
|
||||
jetty.home = /opt/jetty/jetty-home-{VERSION}
|
||||
jetty.base = /opt/jetty/jetty-home-{VERSION}
|
||||
|
||||
Properties:
|
||||
-----------
|
||||
|
@ -183,12 +183,12 @@ The following is the equivalent Java command line for what the `start.jar` boots
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[user]$ cd jetty-distribution-{VERSION}
|
||||
[jetty-distribution-{VERSION}]$ echo jetty.http.port=8080 > /tmp/jetty.properties
|
||||
[jetty-distribution-{VERSION}]$ export JETTY_HOME=`pwd`
|
||||
[jetty-distribution-{VERSION}]$ export JETTY_BASE=`pwd`
|
||||
[jetty-distribution-{VERSION}]$ export JETTY_VERSION="${project.version}"
|
||||
[jetty-distribution-{VERSION}]$ java -Djetty.home=$JETTY_HOME \
|
||||
[user]$ cd jetty-home-{VERSION}
|
||||
[jetty-home-{VERSION}]$ echo jetty.http.port=8080 > /tmp/jetty.properties
|
||||
[jetty-home-{VERSION}]$ export JETTY_HOME=`pwd`
|
||||
[jetty-home-{VERSION}]$ export JETTY_BASE=`pwd`
|
||||
[jetty-home-{VERSION}]$ export JETTY_VERSION="${project.version}"
|
||||
[jetty-home-{VERSION}]$ java -Djetty.home=$JETTY_HOME \
|
||||
-Djetty.base=$JETTY_BASE \
|
||||
-cp \
|
||||
$JETTY_HOME/lib/jetty-servlet-api-4.0.2.jar\
|
||||
|
@ -209,8 +209,8 @@ You can further simplify the startup of this server by using the INI template de
|
|||
|
||||
[source,screen,subs="{sub-order}"]
|
||||
....
|
||||
[user]$ cd jetty-distribution-{VERSION}
|
||||
[jetty-distribution-{VERSION}]$ mkdir example-base
|
||||
[user]$ cd jetty-home-{VERSION}
|
||||
[jetty-home-{VERSION}]$ mkdir example-base
|
||||
[example-base]$ cd example-base
|
||||
[example-base]$ ls -la
|
||||
total 8
|
||||
|
|
|
@ -29,23 +29,23 @@ The minimum steps to get Jetty to run as a Service include:
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[/opt/jetty]# tar -zxf /home/user/downloads/jetty-distribution-{VERSION}.tar.gz
|
||||
[/opt/jetty]# cd jetty-distribution-{VERSION}/
|
||||
[/opt/jetty/jetty-distribution-{VERSION}]# ls
|
||||
[/opt/jetty]# tar -zxf /home/user/downloads/jetty-home-{VERSION}.tar.gz
|
||||
[/opt/jetty]# cd jetty-home-{VERSION}/
|
||||
[/opt/jetty/jetty-home-{VERSION}]# ls
|
||||
bin lib modules resources start.jar
|
||||
demo-base license-eplv10-aslv20.html notice.html start.d VERSION.txt
|
||||
etc logs README.TXT start.ini webapps
|
||||
|
||||
[/opt/jetty/jetty-distribution-{VERSION}]# cp bin/jetty.sh /etc/init.d/jetty
|
||||
[/opt/jetty/jetty-distribution-{VERSION}]# echo JETTY_HOME=`pwd` > /etc/default/jetty
|
||||
[/opt/jetty/jetty-distribution-{VERSION}]# cat /etc/default/jetty
|
||||
JETTY_HOME=/opt/jetty/jetty-distribution-{VERSION}
|
||||
[/opt/jetty/jetty-home-{VERSION}]# cp bin/jetty.sh /etc/init.d/jetty
|
||||
[/opt/jetty/jetty-home-{VERSION}]# echo JETTY_HOME=`pwd` > /etc/default/jetty
|
||||
[/opt/jetty/jetty-home-{VERSION}]# cat /etc/default/jetty
|
||||
JETTY_HOME=/opt/jetty/jetty-home-{VERSION}
|
||||
|
||||
[/opt/jetty/jetty-distribution-{VERSION}]# service jetty start
|
||||
[/opt/jetty/jetty-home-{VERSION}]# service jetty start
|
||||
Starting Jetty: OK Wed Nov 20 10:26:53 MST 2013
|
||||
....
|
||||
|
||||
From this demonstration we can see that Jetty started successfully as a Unix Service from the `/opt/jetty/jetty-distribution-{VERSION}` directory.
|
||||
From this demonstration we can see that Jetty started successfully as a Unix Service from the `/opt/jetty/jetty-home-{VERSION}` directory.
|
||||
|
||||
This configuration works well but it is running Jetty as the root user.
|
||||
|
||||
|
@ -131,13 +131,13 @@ Unpack it into place.
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
[/opt/jetty]# tar -zxf /home/user/Downloads/jetty-distribution-{VERSION}.tar.gz
|
||||
[/opt/jetty]# tar -zxf /home/user/Downloads/jetty-home-{VERSION}.tar.gz
|
||||
[/opt/jetty]# ls -F
|
||||
jetty-distribution-{VERSION}/
|
||||
jetty-home-{VERSION}/
|
||||
[/opt/jetty]# mkdir /opt/jetty/temp
|
||||
....
|
||||
|
||||
It might seem strange or undesirable to unpack the first portion of the jetty-distribution directory name too.
|
||||
It might seem strange or undesirable to unpack the first portion of the jetty-home directory name too.
|
||||
But starting with Jetty 9 the split between `${jetty.home}` and `${jetty.base}` allows for easier upgrades of Jetty itself while isolating your webapp specific configuration.
|
||||
For more information on the Jetty home and base concepts see the section on managing a Jetty installation link:#startup-base-and-home[earlier in this Chapter.]
|
||||
|
||||
|
@ -149,15 +149,15 @@ The directory at `/opt/web/mybase` is going to be a `${jetty.base}`, so lets con
|
|||
|
||||
[TIP]
|
||||
--
|
||||
In past versions of Jetty, you would configure / modify / add to the `jetty-distribution` directory directly.
|
||||
While this is still supported, we encourage you to setup a proper `${jetty.base}` directory, as it will benefit you with easier `jetty-distribution` upgrades in the future.
|
||||
In past versions of Jetty, you would configure / modify / add to the `jetty-home` directory directly.
|
||||
While this is still supported, we encourage you to setup a proper `${jetty.base}` directory, as it will benefit you with easier `jetty-home` upgrades in the future.
|
||||
--
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
# cd /opt/web/mybase/
|
||||
[/opt/web/mybase]# ls
|
||||
[/opt/web/mybase]# java -jar /opt/jetty/jetty-distribution-{VERSION}/start.jar \
|
||||
[/opt/web/mybase]# java -jar /opt/jetty/jetty-home-{VERSION}/start.jar \
|
||||
--add-to-start=deploy,http,console-capture
|
||||
INFO : webapp transitively enabled, ini template available with --add-to-start=webapp
|
||||
INFO : server transitively enabled, ini template available with --add-to-start=server
|
||||
|
@ -218,8 +218,8 @@ Next we need to make the Unix System aware that we have a new Jetty Service that
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
# cp /opt/jetty/jetty-distribution-{VERSION}/bin/jetty.sh /etc/init.d/jetty
|
||||
# echo "JETTY_HOME=/opt/jetty/jetty-distribution-{VERSION}" > /etc/default/jetty
|
||||
# cp /opt/jetty/jetty-home-{VERSION}/bin/jetty.sh /etc/init.d/jetty
|
||||
# echo "JETTY_HOME=/opt/jetty/jetty-home-{VERSION}" > /etc/default/jetty
|
||||
# echo "JETTY_BASE=/opt/web/mybase" >> /etc/default/jetty
|
||||
# echo "TMPDIR=/opt/jetty/temp" >> /etc/default/jetty
|
||||
....
|
||||
|
@ -231,31 +231,31 @@ Test out the configuration:
|
|||
# service jetty status
|
||||
Checking arguments to Jetty:
|
||||
START_INI = /opt/web/mybase/start.ini
|
||||
JETTY_HOME = /opt/jetty/jetty-distribution-{VERSION}
|
||||
JETTY_HOME = /opt/jetty/jetty-home-{VERSION}
|
||||
JETTY_BASE = /opt/web/mybase
|
||||
JETTY_CONF = /opt/jetty/jetty-distribution-{VERSION}/etc/jetty.conf
|
||||
JETTY_CONF = /opt/jetty/jetty-home-{VERSION}/etc/jetty.conf
|
||||
JETTY_PID = /var/run/jetty.pid
|
||||
JETTY_START = /opt/jetty/jetty-distribution-{VERSION}/start.jar
|
||||
JETTY_START = /opt/jetty/jetty-home-{VERSION}/start.jar
|
||||
CLASSPATH =
|
||||
JAVA = /usr/bin/java
|
||||
JAVA_OPTIONS = -Djetty.state=/opt/web/mybase/jetty.state
|
||||
-Djetty.logs=/opt/web/mybase/logs
|
||||
-Djetty.home=/opt/jetty/jetty-distribution-{VERSION}
|
||||
-Djetty.home=/opt/jetty/jetty-home-{VERSION}
|
||||
-Djetty.base=/opt/web/mybase
|
||||
-Djava.io.tmpdir=/opt/jetty/temp
|
||||
JETTY_ARGS = console-capture.xml jetty-started.xml
|
||||
RUN_CMD = /usr/bin/java
|
||||
-Djetty.state=/opt/web/mybase/jetty.state
|
||||
-Djetty.logs=/opt/web/mybase/logs
|
||||
-Djetty.home=/opt/jetty/jetty-distribution-{VERSION}
|
||||
-Djetty.home=/opt/jetty/jetty-home-{VERSION}
|
||||
-Djetty.base=/opt/web/mybase
|
||||
-Djava.io.tmpdir=/opt/jetty/temp
|
||||
-jar /opt/jetty/jetty-distribution-{VERSION}/start.jar
|
||||
-jar /opt/jetty/jetty-home-{VERSION}/start.jar
|
||||
console-capture.xml
|
||||
jetty-started.xml
|
||||
....
|
||||
|
||||
You now have a configured `${jetty.base}` in `/opt/web/mybase` and a `${jetty.home}` in `/opt/jetty/jetty-distribution-{VERSION}`, along with the service level files necessary to start the service.
|
||||
You now have a configured `${jetty.base}` in `/opt/web/mybase` and a `${jetty.home}` in `/opt/jetty/jetty-home-{VERSION}`, along with the service level files necessary to start the service.
|
||||
|
||||
Test the service to make sure it starts up and runs successfully.
|
||||
|
||||
|
|
|
@ -79,7 +79,7 @@ Java HotSpot(TM) 64-Bit Server VM (build 24.45-b08, mixed mode)
|
|||
|
||||
Download a copy of the ZIP distribution from the link:#jetty-downloading[Official Eclipse Download Site]
|
||||
|
||||
Extract the contents of the `jetty-distribution-{VERSION}` directory to `C:\opt\jetty`
|
||||
Extract the contents of the `jetty-home-{VERSION}` directory to `C:\opt\jetty`
|
||||
|
||||
Once complete, the contents of the `C:\opt\jetty` directory should look like this:
|
||||
|
||||
|
|
|
@ -19,9 +19,9 @@
|
|||
[[og-begin-install]]
|
||||
==== Installing Eclipse Jetty
|
||||
|
||||
After the download, unpacking the Eclipse Jetty distribution will extract the files into a directory called `jetty-distribution-VERSION`, where `VERSION` is the version that you downloaded, for example `10.0.0`, so that the directory is called `jetty-distribution-10.0.0`.
|
||||
After the download, unpacking Eclipse Jetty will extract the files into a directory called `jetty-home-VERSION`, where `VERSION` is the version that you downloaded, for example `10.0.0`, so that the directory is called `jetty-home-10.0.0`.
|
||||
|
||||
Unpack the Eclipse Jetty distribution compressed file in a convenient location, for example under `/opt`.
|
||||
Unpack Eclipse Jetty compressed file in a convenient location, for example under `/opt`.
|
||||
|
||||
NOTE: For Windows users, you should unpack Jetty to a path that does not contain spaces.
|
||||
|
||||
|
|
|
@ -21,16 +21,30 @@
|
|||
|
||||
TODO: review in light of Jetty 10
|
||||
|
||||
The most basic way of starting the Jetty standalone server is to execute the `start.jar`, which is a bootstrap for starting Jetty with the configuration you want.
|
||||
The most basic way of starting the Jetty standalone server is to execute the `start.jar` from a base directory containing
|
||||
the configuration of jetty:
|
||||
|
||||
----
|
||||
[jetty-distribution-{VERSION}]$ java -jar start.jar
|
||||
2013-09-23 11:27:06.654:INFO:oejs.Server:main: jetty-{VERSION}
|
||||
[] mkdir /var/jetty-base
|
||||
[] cd /var/jetty-base
|
||||
[] java -jar $JETTY_HOME/start.jar
|
||||
ERROR : No enabled jetty modules found!
|
||||
...
|
||||
----
|
||||
|
||||
Jetty is a highly modularized web server container.
|
||||
Very little is mandatory and required, and most components are optional; you enable or disable them according to the needs of your environment.
|
||||
Jetty is a highly modularized web server container. Very little is mandatory and required, and most components are optional; you enable or disable them according to the needs of your environment. You use start.jar to configure the modules:
|
||||
|
||||
----
|
||||
[] java -jar $JETTY_HOME/start.jar --add-module=http
|
||||
...
|
||||
INFO : http initialized in ${jetty.base}/start.d/http.ini
|
||||
...
|
||||
|
||||
[] java -jar $JETTY_HOME/start.jar
|
||||
2020-12-02 09:31:45.563:INFO :oejs.Server:main: jetty-10.0.0; built: 2020-11-30T14:38:10.953Z; git: cac070fdb134df192252e99653d99d7c3fb91b87; jvm 15.0.1+9
|
||||
2020-12-02 09:31:45.601:INFO :oejs.AbstractConnector:main: Started ServerConnector@3eb7fc54{HTTP/1.1, (http/1.1)}{0.0.0.0:8080}
|
||||
2020-12-02 09:31:45.615:INFO :oejs.Server:main: Started Server@55a561cf{STARTING}[10.0.0,sto=5000] @760ms
|
||||
----
|
||||
|
||||
At its most basic, you configure Jetty from two elements:
|
||||
|
||||
|
|
|
@ -1,67 +0,0 @@
|
|||
//
|
||||
// ========================================================================
|
||||
// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others.
|
||||
//
|
||||
// This program and the accompanying materials are made available under
|
||||
// the terms of the Eclipse Public License 2.0 which is available at
|
||||
// https://www.eclipse.org/legal/epl-2.0
|
||||
//
|
||||
// This Source Code may also be made available under the following
|
||||
// Secondary Licenses when the conditions for such availability set
|
||||
// forth in the Eclipse Public License, v. 2.0 are satisfied:
|
||||
// the Apache License v2.0 which is available at
|
||||
// https://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
|
||||
// ========================================================================
|
||||
//
|
||||
|
||||
package org.eclipse.jetty.gcloud.session;
|
||||
|
||||
import org.eclipse.jetty.security.HashLoginService;
|
||||
import org.eclipse.jetty.server.Server;
|
||||
import org.eclipse.jetty.server.handler.AllowSymLinkAliasChecker;
|
||||
import org.eclipse.jetty.server.session.DefaultSessionCache;
|
||||
import org.eclipse.jetty.server.session.DefaultSessionIdManager;
|
||||
import org.eclipse.jetty.webapp.WebAppContext;
|
||||
|
||||
public class GCloudSessionTester
|
||||
{
|
||||
public static void main(String[] args) throws Exception
|
||||
{
|
||||
if (args.length < 4)
|
||||
System.err.println("Usage: GCloudSessionTester projectid p12file password serviceaccount");
|
||||
|
||||
System.setProperty("org.eclipse.jetty.server.session.LEVEL", "DEBUG");
|
||||
|
||||
Server server = new Server(8080);
|
||||
HashLoginService loginService = new HashLoginService();
|
||||
loginService.setName("Test Realm");
|
||||
loginService.setConfig("../../jetty-distribution/target/distribution/demo-base/resources/realm.properties");
|
||||
server.addBean(loginService);
|
||||
|
||||
DefaultSessionIdManager idmgr = new DefaultSessionIdManager(server);
|
||||
idmgr.setWorkerName("w1");
|
||||
server.setSessionIdManager(idmgr);
|
||||
|
||||
WebAppContext webapp = new WebAppContext();
|
||||
webapp.setContextPath("/");
|
||||
webapp.setWar("../../jetty-distribution/target/distribution/demo-base/webapps/test.war");
|
||||
webapp.addAliasCheck(new AllowSymLinkAliasChecker());
|
||||
GCloudSessionDataStore ds = new GCloudSessionDataStore();
|
||||
|
||||
DefaultSessionCache ss = new DefaultSessionCache(webapp.getSessionHandler());
|
||||
webapp.getSessionHandler().setSessionCache(ss);
|
||||
ss.setSessionDataStore(ds);
|
||||
webapp.getSessionHandler().setSessionIdManager(idmgr);
|
||||
|
||||
// A WebAppContext is a ContextHandler as well so it needs to be set to
|
||||
// the server so it is aware of where to send the appropriate requests.
|
||||
server.setHandler(webapp);
|
||||
|
||||
// Start things up!
|
||||
server.start();
|
||||
|
||||
server.join();
|
||||
}
|
||||
}
|
|
@ -6,7 +6,7 @@
|
|||
<fileSets>
|
||||
<fileSet>
|
||||
<directory>${basedir}/target/dist-src</directory>
|
||||
<outputDirectory>jetty-distribution-${version}-site-component</outputDirectory>
|
||||
<outputDirectory>jetty-home-${version}-site-component</outputDirectory>
|
||||
<includes>
|
||||
<include>target/site/**</include>
|
||||
<include>README**</include>
|
||||
|
|
|
@ -74,7 +74,7 @@
|
|||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-deploy-plugin</artifactId>
|
||||
<configuration>
|
||||
<!-- must deploy: required for jetty-distribution -->
|
||||
<!-- must not deploy -->
|
||||
<skip>false</skip>
|
||||
</configuration>
|
||||
</plugin>
|
||||
|
|
|
@ -106,18 +106,18 @@ public class MavenLocalRepoFileInitializerTest
|
|||
public void testGetCoordinateZip()
|
||||
{
|
||||
MavenLocalRepoFileInitializer repo = new MavenLocalRepoFileInitializer(baseHome);
|
||||
String ref = "maven://org.eclipse.jetty/jetty-distribution/9.3.x/zip";
|
||||
String ref = "maven://org.eclipse.jetty/jetty-home/10.0.0/zip";
|
||||
Coordinates coords = repo.getCoordinates(URI.create(ref));
|
||||
assertThat("Coordinates", coords, notNullValue());
|
||||
|
||||
assertThat("coords.groupId", coords.groupId, is("org.eclipse.jetty"));
|
||||
assertThat("coords.artifactId", coords.artifactId, is("jetty-distribution"));
|
||||
assertThat("coords.version", coords.version, is("9.3.x"));
|
||||
assertThat("coords.artifactId", coords.artifactId, is("jetty-home"));
|
||||
assertThat("coords.version", coords.version, is("10.0.0"));
|
||||
assertThat("coords.type", coords.type, is("zip"));
|
||||
assertThat("coords.classifier", coords.classifier, nullValue());
|
||||
|
||||
assertThat("coords.toCentralURI", coords.toCentralURI().toASCIIString(),
|
||||
is("https://repo1.maven.org/maven2/org/eclipse/jetty/jetty-distribution/9.3.x/jetty-distribution-9.3.x.zip"));
|
||||
is("https://repo1.maven.org/maven2/org/eclipse/jetty/jetty-home/10.0.0/jetty-home-10.0.0.zip"));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
|
@ -53,8 +53,8 @@ public class CorrectMavenCentralRefs
|
|||
|
||||
// Test to make sure we are in right directory
|
||||
Path rootPomXml = buildRoot.resolve("pom.xml");
|
||||
Path distPomXml = buildRoot.resolve("jetty-distribution/pom.xml");
|
||||
if (!Files.exists(rootPomXml) || !Files.exists(distPomXml))
|
||||
Path homePomXml = buildRoot.resolve("jetty-home/pom.xml");
|
||||
if (!Files.exists(rootPomXml) || !Files.exists(homePomXml))
|
||||
{
|
||||
System.err.println("Not build root directory: " + buildRoot);
|
||||
System.exit(-1);
|
||||
|
|
|
@ -34,7 +34,7 @@ import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
|
|||
* Utility class to rebuild the src/test/resources/dist-home from the active build tree.
|
||||
* <p>
|
||||
* Not really meant to be run with each build. Nor is it a good idea to attempt to do that (as this would introduce a dependency from jetty-start ->
|
||||
* jetty-distribution which is a circular dependency)
|
||||
* jetty-home which is a circular dependency)
|
||||
*/
|
||||
public class RebuildTestResources
|
||||
{
|
||||
|
@ -42,7 +42,7 @@ public class RebuildTestResources
|
|||
|
||||
public static void main(String[] args)
|
||||
{
|
||||
File realDistHome = MavenTestingUtils.getProjectDir("../jetty-distribution/target/distribution");
|
||||
File realDistHome = MavenTestingUtils.getProjectDir("../jetty-home/target/jetty-home");
|
||||
File outputDir = MavenTestingUtils.getTestResourceDir("dist-home");
|
||||
try
|
||||
{
|
||||
|
|
|
@ -1,824 +0,0 @@
|
|||
//
|
||||
// ========================================================================
|
||||
// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others.
|
||||
//
|
||||
// This program and the accompanying materials are made available under
|
||||
// the terms of the Eclipse Public License 2.0 which is available at
|
||||
// https://www.eclipse.org/legal/epl-2.0
|
||||
//
|
||||
// This Source Code may also be made available under the following
|
||||
// Secondary Licenses when the conditions for such availability set
|
||||
// forth in the Eclipse Public License, v. 2.0 are satisfied:
|
||||
// the Apache License v2.0 which is available at
|
||||
// https://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
|
||||
// ========================================================================
|
||||
//
|
||||
|
||||
package org.eclipse.jetty.test.support;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.net.URI;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.CountDownLatch;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import org.eclipse.jetty.toolchain.test.FS;
|
||||
import org.eclipse.jetty.toolchain.test.IO;
|
||||
import org.eclipse.jetty.toolchain.test.JAR;
|
||||
import org.eclipse.jetty.toolchain.test.MavenTestingUtils;
|
||||
import org.eclipse.jetty.toolchain.test.PathAssert;
|
||||
import org.eclipse.jetty.toolchain.test.jupiter.WorkDir;
|
||||
import org.junit.jupiter.api.Assertions;
|
||||
|
||||
/**
|
||||
* Basic process based executor for using the Jetty Distribution along with custom configurations to perform basic
|
||||
* <p>
|
||||
* Allows for a test specific directory, that is a copied jetty-distribution, and then modified for the test specific testing required.
|
||||
* <p>
|
||||
* Requires that you setup the maven-dependency-plugin appropriately for the base distribution you want to use, along with any other dependencies (wars, libs,
|
||||
* etc..) that you may need from other maven projects.
|
||||
* <p>
|
||||
* Maven Dependency Plugin Setup:
|
||||
*
|
||||
* <pre>
|
||||
* <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
* xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||
*
|
||||
* <!-- Common Destination Directories -->
|
||||
*
|
||||
* <properties>
|
||||
* <test-wars-dir>${project.build.directory}/test-wars</test-wars-dir>
|
||||
* <test-libs-dir>${project.build.directory}/test-libs</test-libs-dir>
|
||||
* <test-distro-dir>${project.build.directory}/test-dist</test-distro-dir>
|
||||
* </properties>
|
||||
*
|
||||
* <build>
|
||||
* <plugins>
|
||||
* <plugin>
|
||||
* <groupId>org.apache.maven.plugins</groupId>
|
||||
* <artifactId>maven-dependency-plugin</artifactId>
|
||||
* <version>2.1</version>
|
||||
* <executions>
|
||||
*
|
||||
* <!-- Copy LIB and WAR dependencies into place that JettyDistro can use them -->
|
||||
*
|
||||
* <execution>
|
||||
* <id>test-lib-war-copy</id>
|
||||
* <phase>process-test-resources</phase>
|
||||
* <goals>
|
||||
* <goal>copy</goal>
|
||||
* </goals>
|
||||
* <configuration>
|
||||
* <artifactItems>
|
||||
* <artifactItem>
|
||||
* <groupId>org.mortbay.jetty.testwars</groupId>
|
||||
* <artifactId>test-war-java_util_logging</artifactId>
|
||||
* <version>7.3.0</version>
|
||||
* <type>war</type>
|
||||
* <outputDirectory>${test-wars-dir}</outputDirectory>
|
||||
* </artifactItem>
|
||||
* <artifactItem>
|
||||
* <groupId>org.mortbay.jetty</groupId>
|
||||
* <artifactId>jetty-aspect-servlet-api-2.5</artifactId>
|
||||
* <version>7.3.0</version>
|
||||
* <type>jar</type>
|
||||
* <outputDirectory>${test-libs-dir}</outputDirectory>
|
||||
* </artifactItem>
|
||||
* </artifactItems>
|
||||
* <overWriteIfNewer>true</overWriteIfNewer>
|
||||
* <overWrite>true</overWrite>
|
||||
* <stripVersion>true</stripVersion>
|
||||
* </configuration>
|
||||
* </execution>
|
||||
*
|
||||
* <!-- Extract Jetty DISTRIBUTION into place that JettyDistro can use it -->
|
||||
*
|
||||
* <execution>
|
||||
* <id>unpack-test-dist</id>
|
||||
* <phase>process-test-resources</phase>
|
||||
* <goals>
|
||||
* <goal>unpack</goal>
|
||||
* </goals>
|
||||
* <configuration>
|
||||
* <artifactItems>
|
||||
* <artifactItem>
|
||||
* <groupId>org.eclipse.jetty</groupId>
|
||||
* <artifactId>jetty-distribution</artifactId>
|
||||
* <version>7.3.0</version>
|
||||
* <type>zip</type>
|
||||
* <overWrite>true</overWrite>
|
||||
* </artifactItem>
|
||||
* </artifactItems>
|
||||
* <outputAbsoluteArtifactFilename>true</outputAbsoluteArtifactFilename>
|
||||
* <outputDirectory>${test-distro-dir}</outputDirectory>
|
||||
* <overWriteSnapshots>true</overWriteSnapshots>
|
||||
* <overWriteIfNewer>true</overWriteIfNewer>
|
||||
* </configuration>
|
||||
* </execution>
|
||||
* </executions>
|
||||
* </plugin>
|
||||
* </plugins>
|
||||
* </build>
|
||||
*
|
||||
* </project>
|
||||
* </pre>
|
||||
* <p>
|
||||
* If you have a specific configuration you want to setup, you'll want to prepare this configuration in an overlay directory underneath the
|
||||
* <code>src/test/resources/</code> directory. <br>
|
||||
* Notes:
|
||||
* <ol>
|
||||
* <li>The {@link JettyDistro} sets up a unique test directory (based on the constructor {@link #JettyDistro(Class)} or {@link #JettyDistro(org.eclipse.jetty.toolchain.test.jupiter.WorkDir)}), by
|
||||
* ensuring the directory is empty, then copying the <code>target/test-dist</code> directory into this new testing directory prior to the test specific changes
|
||||
* to the configuration.<br>
|
||||
* Note: this testing directory is a complete jetty distribution, suitable for executing via the command line for additional testing needs.</li>
|
||||
* <li>The directory name you choose in <code>src/test/resources</code> will be the name you use in the {@link #overlayConfig(String)} method to provide
|
||||
* replacement configurations for the Jetty Distribution.</li>
|
||||
* <li>You'll want to {@link #delete(String)} any files and/or directories from the standard distribution prior to using the {@link #overlayConfig(String)}
|
||||
* method.</li>
|
||||
* <li>Use the {@link #copyLib(String, String)} method to copy JAR files from the <code>target/test-libs</code> directory (created and managed above using the
|
||||
* <code>maven-dependency-plugin</code>) to copy the lib into the test specific.</li>
|
||||
* <li>Use the {@link #copyTestWar(String)} method to copy WAR files from the <code>target/test-wars</code> directory (created and managed above using the
|
||||
* <code>maven-dependency-plugin</code>) to copy the WAR into the test specific directory.</li>
|
||||
* </ol>
|
||||
* <p>
|
||||
* Next you'll want to use Junit 4.8+ and the <code>@BeforeClass</code> and <code>@AfterClass</code> annotations to setup the <code>JettyDistro</code>
|
||||
* class for setting up your testing configuration.
|
||||
* <p>
|
||||
* Example Test Case using {@link JettyDistro} class
|
||||
*
|
||||
* <pre>
|
||||
* public class MySampleTest
|
||||
* {
|
||||
* private static JettyDistro jetty;
|
||||
*
|
||||
* @BeforeClass
|
||||
* public static void initJetty() throws Exception
|
||||
* {
|
||||
* jetty = new JettyDistro(MySampleTest.class);
|
||||
*
|
||||
* jetty.copyTestWar("test-war-java_util_logging.war");
|
||||
* jetty.copyTestWar("test-war-policy.war");
|
||||
*
|
||||
* jetty.delete("webapps/test.war");
|
||||
* jetty.delete("contexts/test.d");
|
||||
* jetty.delete("contexts/javadoc.xml");
|
||||
* jetty.delete("contexts/test.xml");
|
||||
*
|
||||
* jetty.overlayConfig("no_security");
|
||||
*
|
||||
* jetty.setDebug(true);
|
||||
*
|
||||
* jetty.start();
|
||||
* }
|
||||
*
|
||||
* @AfterClass
|
||||
* public static void shutdownJetty() throws Exception
|
||||
* {
|
||||
* if (jetty != null)
|
||||
* {
|
||||
* jetty.stop();
|
||||
* }
|
||||
* }
|
||||
*
|
||||
* @Test
|
||||
* public void testRequest() throws Exception
|
||||
* {
|
||||
* SimpleRequest request = new SimpleRequest(jetty.getBaseUri());
|
||||
* String path = "/test-war-policy/security/PRACTICAL/testFilsystem");
|
||||
* String response = request.getString(path);
|
||||
* assertEquals("Success", response);
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*/
|
||||
public class JettyDistro
|
||||
{
|
||||
private String artifactName = "jetty-distribution";
|
||||
private long startTime = 60;
|
||||
private TimeUnit timeUnit = TimeUnit.SECONDS;
|
||||
|
||||
private File jettyHomeDir;
|
||||
private Process pid;
|
||||
private URI baseUri;
|
||||
|
||||
private String jmxUrl;
|
||||
|
||||
private boolean _debug = false;
|
||||
|
||||
/**
|
||||
* Setup the JettyHome as belonging in a testing directory associated with a testing clazz.
|
||||
*
|
||||
* @param clazz the testing class using this JettyDistro
|
||||
* @throws IOException if unable to copy unpacked distribution into place for the provided testing directory
|
||||
*/
|
||||
public JettyDistro(Class<?> clazz) throws IOException
|
||||
{
|
||||
this(clazz, null);
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup the JettyHome as belonging in a testing directory associated with a testing clazz.
|
||||
*
|
||||
* @param clazz the testing class using this JettyDistro
|
||||
* @param artifact name of jetty distribution artifact
|
||||
* @throws IOException if unable to copy unpacked distribution into place for the provided testing directory
|
||||
*/
|
||||
public JettyDistro(Class<?> clazz, String artifact) throws IOException
|
||||
{
|
||||
this.jettyHomeDir = MavenTestingUtils.getTargetTestingPath(clazz, "jettyHome").toFile();
|
||||
if (artifact != null)
|
||||
{
|
||||
this.artifactName = artifact;
|
||||
}
|
||||
|
||||
copyBaseDistro();
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup the JettyHome as belonging to a specific testing method directory
|
||||
*
|
||||
* @param testdir the testing directory to use as the JettyHome for this JettyDistro
|
||||
* @throws IOException if unable to copy unpacked distribution into place for the provided testing directory
|
||||
*/
|
||||
public JettyDistro(WorkDir testdir) throws IOException
|
||||
{
|
||||
this.jettyHomeDir = testdir.getPath().toFile();
|
||||
copyBaseDistro();
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup the JettyHome as belonging to a specific testing method directory
|
||||
*
|
||||
* @param testdir the testing directory to use as the JettyHome for this JettyDistro
|
||||
* @param artifact name of jetty distribution artifact
|
||||
* @throws IOException if unable to copy unpacked distribution into place for the provided testing directory
|
||||
*/
|
||||
public JettyDistro(WorkDir testdir, String artifact) throws IOException
|
||||
{
|
||||
this.jettyHomeDir = testdir.getPath().toFile();
|
||||
if (artifact != null)
|
||||
{
|
||||
this.artifactName = artifact;
|
||||
}
|
||||
|
||||
copyBaseDistro();
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws IOException if unable to copy unpacked distribution into place for the provided testing directory
|
||||
*/
|
||||
private void copyBaseDistro() throws IOException
|
||||
{
|
||||
// The outputDirectory for the maven side dependency:unpack goal.
|
||||
File distroUnpackDir = MavenTestingUtils.getTargetFile("test-dist");
|
||||
PathAssert.assertDirExists(artifactName + " dependency:unpack", distroUnpackDir);
|
||||
|
||||
// The actual jetty-distribution-${version} directory is under this directory.
|
||||
// Lets find it.
|
||||
File[] subdirs = distroUnpackDir.listFiles(path ->
|
||||
{
|
||||
if (!path.isDirectory())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
return path.getName().startsWith(artifactName + "-");
|
||||
}
|
||||
);
|
||||
|
||||
if (subdirs.length == 0)
|
||||
{
|
||||
// No jetty-distribution found.
|
||||
StringBuilder err = new StringBuilder();
|
||||
err.append("No target/test-dist/");
|
||||
err.append(artifactName);
|
||||
err.append("-${version} directory found.");
|
||||
err.append("\n To fix this, run 'mvn process-test-resources' to create the directory.");
|
||||
throw new IOException(err.toString());
|
||||
}
|
||||
|
||||
if (subdirs.length != 1)
|
||||
{
|
||||
// Too many jetty-distributions found.
|
||||
StringBuilder err = new StringBuilder();
|
||||
err.append("Too many target/test-dist/");
|
||||
err.append(artifactName);
|
||||
err.append("-${version} directories found.");
|
||||
for (File dir : subdirs)
|
||||
{
|
||||
err.append("\n ").append(dir.getAbsolutePath());
|
||||
}
|
||||
err.append("\n To fix this, run 'mvn clean process-test-resources' to recreate the target/test-dist directory.");
|
||||
throw new IOException(err.toString());
|
||||
}
|
||||
|
||||
File distroSrcDir = subdirs[0];
|
||||
FS.ensureEmpty(jettyHomeDir);
|
||||
System.out.printf("Copying Jetty Distribution: %s%n", distroSrcDir.getAbsolutePath());
|
||||
System.out.printf(" To Testing Dir: %s%n", jettyHomeDir.getAbsolutePath());
|
||||
IO.copyDir(distroSrcDir, jettyHomeDir);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the $(jetty.home) directory being used for this JettyDistro
|
||||
*
|
||||
* @return the jetty.home directory being used
|
||||
*/
|
||||
public File getJettyHomeDir()
|
||||
{
|
||||
return this.jettyHomeDir;
|
||||
}
|
||||
|
||||
/**
|
||||
* Copy a war file from ${project.basedir}/target/test-wars/${testWarFilename} into the ${jetty.home}/webapps/ directory
|
||||
*
|
||||
* @param testWarFilename the war file to copy (must exist)
|
||||
* @throws IOException if unable to copy the war file.
|
||||
*/
|
||||
public void copyTestWar(String testWarFilename) throws IOException
|
||||
{
|
||||
File srcWar = MavenTestingUtils.getTargetFile("test-wars/" + testWarFilename);
|
||||
File destWar = new File(jettyHomeDir, FS.separators("webapps/" + testWarFilename));
|
||||
FS.ensureDirExists(destWar.getParentFile());
|
||||
IO.copyFile(srcWar, destWar);
|
||||
}
|
||||
|
||||
/**
|
||||
* Copy an arbitrary file from <code>src/test/resources/${resourcePath}</code> to the testing directory.
|
||||
*
|
||||
* @param resourcePath the relative path for file content within the <code>src/test/resources</code> directory.
|
||||
* @param outputPath the testing directory relative output path for the file output (will result in a file with the outputPath name being created)
|
||||
* @throws IOException if unable to copy resource file
|
||||
*/
|
||||
public void copyResource(String resourcePath, String outputPath) throws IOException
|
||||
{
|
||||
File srcFile = MavenTestingUtils.getTestResourceFile(resourcePath);
|
||||
File destFile = new File(jettyHomeDir, FS.separators(outputPath));
|
||||
FS.ensureDirExists(destFile.getParentFile());
|
||||
IO.copyFile(srcFile, destFile);
|
||||
}
|
||||
|
||||
/**
|
||||
* Copy an arbitrary file from <code>target/test-libs/${libFilename}</code> to the testing directory.
|
||||
*
|
||||
* @param libFilename the <code>target/test-libs/${libFilename}</code> to copy
|
||||
* @param outputPath the destination testing directory relative output path for the lib. (will result in a file with the outputPath name being created)
|
||||
* @throws IOException if unable to copy lib
|
||||
*/
|
||||
public void copyLib(String libFilename, String outputPath) throws IOException
|
||||
{
|
||||
File srcLib = MavenTestingUtils.getTargetFile("test-libs/" + libFilename);
|
||||
File destLib = new File(jettyHomeDir, FS.separators(outputPath));
|
||||
FS.ensureDirExists(destLib.getParentFile());
|
||||
IO.copyFile(srcLib, destLib);
|
||||
}
|
||||
|
||||
/**
|
||||
* Copy the <code>${project.basedir}/src/main/config/</code> tree into the testing directory.
|
||||
*
|
||||
* @throws IOException if unable to copy the directory tree
|
||||
*/
|
||||
public void copyProjectMainConfig() throws IOException
|
||||
{
|
||||
File srcDir = MavenTestingUtils.getProjectDir("src/main/config");
|
||||
IO.copyDir(srcDir, jettyHomeDir);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a <code>${jetty.home}/lib/self/${jarFilename}</code> jar file from the content in the <code>${project.basedir}/target/classes/</code> directory.
|
||||
*
|
||||
* @throws IOException if unable to copy the directory tree
|
||||
*/
|
||||
public void createProjectLib(String jarFilename) throws IOException
|
||||
{
|
||||
File srcDir = MavenTestingUtils.getTargetFile("classes");
|
||||
File libSelfDir = new File(jettyHomeDir, FS.separators("lib/self"));
|
||||
FS.ensureDirExists(libSelfDir);
|
||||
File jarFile = new File(libSelfDir, jarFilename);
|
||||
JAR.create(srcDir, jarFile);
|
||||
}
|
||||
|
||||
/**
|
||||
* Unpack an arbitrary config from <code>target/test-configs/${configFilename}</code> to the testing directory.
|
||||
*
|
||||
* @param configFilename the <code>target/test-configs/${configFilename}</code> to copy
|
||||
* @throws IOException if unable to unpack config file
|
||||
*/
|
||||
public void unpackConfig(String configFilename) throws IOException
|
||||
{
|
||||
File srcConfig = MavenTestingUtils.getTargetFile("test-configs/" + configFilename);
|
||||
JAR.unpack(srcConfig, jettyHomeDir);
|
||||
}
|
||||
|
||||
/**
|
||||
* Delete a File or Directory found in the ${jetty.home} directory.
|
||||
*
|
||||
* @param path the path to delete. (can be a file or directory)
|
||||
*/
|
||||
public void delete(String path)
|
||||
{
|
||||
File jettyPath = new File(jettyHomeDir, FS.separators(path));
|
||||
FS.delete(jettyPath);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the baseUri being used for this Jetty Process Instance.
|
||||
*
|
||||
* @return the base URI for this Jetty Process Instance.
|
||||
*/
|
||||
public URI getBaseUri()
|
||||
{
|
||||
return this.baseUri;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the JMX URL being used for this Jetty Process Instance.
|
||||
*
|
||||
* @return the JMX URL for this Jetty Process Instance.
|
||||
*/
|
||||
public String getJmxUrl()
|
||||
{
|
||||
return this.jmxUrl;
|
||||
}
|
||||
|
||||
/**
|
||||
* Take the directory contents from ${project.basedir}/src/test/resources/${testConfigName}/ and copy it over whatever happens to be at ${jetty.home}
|
||||
*
|
||||
* @param testConfigName the src/test/resources/ directory name to use as the source diretory for the configuration we are interested in.
|
||||
* @throws IOException if unable to copy directory.
|
||||
*/
|
||||
public void overlayConfig(String testConfigName) throws IOException
|
||||
{
|
||||
File srcDir = MavenTestingUtils.getTestResourceDir(testConfigName);
|
||||
IO.copyDir(srcDir, jettyHomeDir);
|
||||
}
|
||||
|
||||
/**
|
||||
* Start the jetty server
|
||||
*
|
||||
* @throws IOException if unable to start the server.
|
||||
*/
|
||||
public void start() throws IOException
|
||||
{
|
||||
List<String> commands = new ArrayList<String>();
|
||||
commands.add(getJavaBin());
|
||||
|
||||
commands.add("-Djetty.home=" + jettyHomeDir.getAbsolutePath());
|
||||
|
||||
// Do a dry run first to get the exact command line for Jetty process
|
||||
commands.add("-jar");
|
||||
commands.add("start.jar");
|
||||
commands.add("jetty.http.port=0");
|
||||
if (_debug)
|
||||
{
|
||||
commands.add("-D.DEBUG=true");
|
||||
}
|
||||
commands.add("--dry-run");
|
||||
|
||||
ProcessBuilder pbCmd = new ProcessBuilder(commands);
|
||||
pbCmd.directory(jettyHomeDir);
|
||||
|
||||
String cmdLine = null;
|
||||
Process pidCmd = pbCmd.start();
|
||||
try
|
||||
{
|
||||
cmdLine = readOutputLine(pidCmd);
|
||||
}
|
||||
finally
|
||||
{
|
||||
pidCmd.destroy();
|
||||
}
|
||||
|
||||
if (cmdLine == null || !cmdLine.contains("XmlConfiguration"))
|
||||
{
|
||||
Assertions.fail("Unable to get Jetty command line");
|
||||
}
|
||||
|
||||
// Need to breakdown commandline into parts, as spaces in command line will cause failures.
|
||||
List<String> execCommands = splitAndUnescapeCommandLine(cmdLine);
|
||||
|
||||
System.out.printf("Executing: %s%n", cmdLine);
|
||||
System.out.printf("Working Dir: %s%n", jettyHomeDir.getAbsolutePath());
|
||||
|
||||
pbCmd = new ProcessBuilder(execCommands);
|
||||
pid = pbCmd.start();
|
||||
|
||||
ConsoleParser parser = new ConsoleParser();
|
||||
List<String[]> jmxList = parser.newPattern("JMX Remote URL: (.*)", 0);
|
||||
List<String[]> connList = parser.newPattern("Started [A-Za-z]*Connector@([0-9]*\\.[0-9]*\\.[0-9]*\\.[0-9]*):([0-9]*)", 1);
|
||||
// DISABLED: This is what exists in Jetty 9+
|
||||
// List<String[]> connList = parser.newPattern("Started [A-Za-z]*Connector@.*[\\({]([0-9]*\\.[0-9]*\\.[0-9]*\\.[0-9]*):([0-9]*)[\\)}].*",1);
|
||||
|
||||
startPump("STDOUT", parser, this.pid.getInputStream());
|
||||
startPump("STDERR", parser, this.pid.getErrorStream());
|
||||
|
||||
try
|
||||
{
|
||||
parser.waitForDone(this.startTime, this.timeUnit);
|
||||
|
||||
if (!jmxList.isEmpty())
|
||||
{
|
||||
this.jmxUrl = jmxList.get(0)[0];
|
||||
System.out.printf("## Found JMX connector at %s%n", this.jmxUrl);
|
||||
}
|
||||
|
||||
if (!connList.isEmpty())
|
||||
{
|
||||
String[] params = connList.get(0);
|
||||
if (params.length == 2)
|
||||
{
|
||||
this.baseUri = URI.create("http://localhost:" + params[1] + "/");
|
||||
}
|
||||
System.out.printf("## Found Jetty connector at host: %s port: %s%n", (Object[])params);
|
||||
}
|
||||
}
|
||||
catch (InterruptedException e)
|
||||
{
|
||||
pid.destroy();
|
||||
Assertions.fail("Unable to get required information within time limit");
|
||||
}
|
||||
}
|
||||
|
||||
public static List<String> splitAndUnescapeCommandLine(CharSequence rawCmdLine)
|
||||
{
|
||||
List<String> cmds = new ArrayList<String>();
|
||||
|
||||
int len = rawCmdLine.length();
|
||||
StringBuilder arg = new StringBuilder();
|
||||
boolean escaped = false;
|
||||
boolean inQuote = false;
|
||||
char c;
|
||||
for (int i = 0; i < len; i++)
|
||||
{
|
||||
c = rawCmdLine.charAt(i);
|
||||
if (escaped)
|
||||
{
|
||||
switch (c)
|
||||
{
|
||||
case 'r':
|
||||
arg.append('\r');
|
||||
break;
|
||||
case 'f':
|
||||
arg.append('\f');
|
||||
break;
|
||||
case 't':
|
||||
arg.append('\t');
|
||||
break;
|
||||
case 'n':
|
||||
arg.append('\n');
|
||||
break;
|
||||
case 'b':
|
||||
arg.append('\b');
|
||||
break;
|
||||
default:
|
||||
arg.append(c);
|
||||
break;
|
||||
}
|
||||
escaped = false;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (c == '\\')
|
||||
{
|
||||
escaped = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if ((c == ' ') && (!inQuote))
|
||||
{
|
||||
// the delim!
|
||||
cmds.add(String.valueOf(arg.toString()));
|
||||
arg.setLength(0);
|
||||
}
|
||||
else if (c == '"')
|
||||
{
|
||||
inQuote = !inQuote;
|
||||
}
|
||||
else
|
||||
{
|
||||
arg.append(c);
|
||||
}
|
||||
}
|
||||
}
|
||||
cmds.add(String.valueOf(arg.toString()));
|
||||
|
||||
return cmds;
|
||||
}
|
||||
|
||||
private String readOutputLine(Process pidCmd) throws IOException
|
||||
{
|
||||
InputStream in = null;
|
||||
InputStreamReader reader = null;
|
||||
BufferedReader buf = null;
|
||||
try
|
||||
{
|
||||
in = pidCmd.getInputStream();
|
||||
reader = new InputStreamReader(in);
|
||||
buf = new BufferedReader(reader);
|
||||
return buf.readLine();
|
||||
}
|
||||
finally
|
||||
{
|
||||
IO.close(buf);
|
||||
IO.close(reader);
|
||||
IO.close(in);
|
||||
}
|
||||
}
|
||||
|
||||
private static class ConsoleParser
|
||||
{
|
||||
private List<ConsolePattern> patterns = new ArrayList<ConsolePattern>();
|
||||
private CountDownLatch latch;
|
||||
private int count;
|
||||
|
||||
public List<String[]> newPattern(String exp, int cnt)
|
||||
{
|
||||
ConsolePattern pat = new ConsolePattern(exp, cnt);
|
||||
patterns.add(pat);
|
||||
count += cnt;
|
||||
|
||||
return pat.getMatches();
|
||||
}
|
||||
|
||||
public void parse(String line)
|
||||
{
|
||||
for (ConsolePattern pat : patterns)
|
||||
{
|
||||
Matcher mat = pat.getMatcher(line);
|
||||
if (mat.find())
|
||||
{
|
||||
int num = 0;
|
||||
int count = mat.groupCount();
|
||||
String[] match = new String[count];
|
||||
while (num++ < count)
|
||||
{
|
||||
match[num - 1] = mat.group(num);
|
||||
}
|
||||
pat.getMatches().add(match);
|
||||
|
||||
if (pat.getCount() > 0)
|
||||
{
|
||||
getLatch().countDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void waitForDone(long timeout, TimeUnit unit) throws InterruptedException
|
||||
{
|
||||
getLatch().await(timeout, unit);
|
||||
}
|
||||
|
||||
private CountDownLatch getLatch()
|
||||
{
|
||||
synchronized (this)
|
||||
{
|
||||
if (latch == null)
|
||||
{
|
||||
latch = new CountDownLatch(count);
|
||||
}
|
||||
}
|
||||
|
||||
return latch;
|
||||
}
|
||||
}
|
||||
|
||||
private static class ConsolePattern
|
||||
{
|
||||
private Pattern pattern;
|
||||
private List<String[]> matches;
|
||||
private int count;
|
||||
|
||||
ConsolePattern(String exp, int cnt)
|
||||
{
|
||||
pattern = Pattern.compile(exp);
|
||||
matches = new ArrayList<String[]>();
|
||||
count = cnt;
|
||||
}
|
||||
|
||||
public Matcher getMatcher(String line)
|
||||
{
|
||||
return pattern.matcher(line);
|
||||
}
|
||||
|
||||
public List<String[]> getMatches()
|
||||
{
|
||||
return matches;
|
||||
}
|
||||
|
||||
public int getCount()
|
||||
{
|
||||
return count;
|
||||
}
|
||||
}
|
||||
|
||||
private void startPump(String mode, ConsoleParser parser, InputStream inputStream)
|
||||
{
|
||||
ConsoleStreamer pump = new ConsoleStreamer(mode, inputStream);
|
||||
pump.setParser(parser);
|
||||
Thread thread = new Thread(pump, "ConsoleStreamer/" + mode);
|
||||
thread.start();
|
||||
}
|
||||
|
||||
/**
|
||||
* enable debug on the jetty process
|
||||
*/
|
||||
public void setDebug(boolean debug)
|
||||
{
|
||||
_debug = debug;
|
||||
}
|
||||
|
||||
private String getJavaBin()
|
||||
{
|
||||
String[] javaexes = new String[]
|
||||
{"java", "java.exe"};
|
||||
|
||||
File javaHomeDir = new File(System.getProperty("java.home"));
|
||||
for (String javaexe : javaexes)
|
||||
{
|
||||
File javabin = new File(javaHomeDir, FS.separators("bin/" + javaexe));
|
||||
if (javabin.exists() && javabin.isFile())
|
||||
{
|
||||
return javabin.getAbsolutePath();
|
||||
}
|
||||
}
|
||||
|
||||
Assertions.fail("Unable to find java bin");
|
||||
return "java";
|
||||
}
|
||||
|
||||
/**
|
||||
* Stop the jetty server
|
||||
*/
|
||||
public void stop()
|
||||
{
|
||||
System.out.println("Stopping JettyDistro ...");
|
||||
if (pid != null)
|
||||
{
|
||||
// TODO: maybe issue a STOP instead?
|
||||
pid.destroy();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Simple streamer for the console output from a Process
|
||||
*/
|
||||
private static class ConsoleStreamer implements Runnable
|
||||
{
|
||||
private String mode;
|
||||
private BufferedReader reader;
|
||||
private ConsoleParser parser;
|
||||
|
||||
public ConsoleStreamer(String mode, InputStream is)
|
||||
{
|
||||
this.mode = mode;
|
||||
this.reader = new BufferedReader(new InputStreamReader(is));
|
||||
}
|
||||
|
||||
public void setParser(ConsoleParser connector)
|
||||
{
|
||||
this.parser = connector;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run()
|
||||
{
|
||||
String line;
|
||||
// System.out.printf("ConsoleStreamer/%s initiated%n",mode);
|
||||
try
|
||||
{
|
||||
while ((line = reader.readLine()) != (null))
|
||||
{
|
||||
if (parser != null)
|
||||
{
|
||||
parser.parse(line);
|
||||
}
|
||||
System.out.println("[" + mode + "] " + line);
|
||||
}
|
||||
}
|
||||
catch (IOException ignore)
|
||||
{
|
||||
/* ignore */
|
||||
}
|
||||
finally
|
||||
{
|
||||
IO.close(reader);
|
||||
}
|
||||
// System.out.printf("ConsoleStreamer/%s finished%n",mode);
|
||||
}
|
||||
}
|
||||
|
||||
public void setStartTime(long startTime, TimeUnit timeUnit)
|
||||
{
|
||||
this.startTime = startTime;
|
||||
this.timeUnit = timeUnit;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue