source: installer/resources/eepsite/jetty.xml @ 6b4f665

Last change on this file since 6b4f665 was 6b4f665, checked in by zzz <zzz@…>, 3 years ago

Add more markers and protection for xml file migration
Add error message for jetty-jmx.xml migration, don't migrate
Update non-default files jetty-rewrite.xml and jetty-jmx.xml

  • Property mode set to 100644
File size: 15.3 KB
Line 
1<?xml version="1.0" encoding="UTF-8" ?> 
2<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure.dtd">
3
4<!-- This configuration supports Jetty 9. Do not remove this line. -->
5
6<!-- ========================================================================= -->
7<!-- This file configures the Jetty server.                                    -->
8<!-- All changes require a restart of I2P.                                     -->
9<!--                                                                           -->
10<!-- Commonly changed settings:                                                -->
11<!--   * host: Change 127.0.0.1 to 0.0.0.0 in the addListener section          -->
12<!--           to access the server directly (bypassing i2p)                   -->
13<!--           from other computers.                                           -->
14<!--   * port: Default 7658 in the addConnector section                         -->
15<!--   * docroot: Change the ResourceBase in the contexts/base-context.xml file -->
16<!--           to serve files from a different location.                       -->
17<!--   * threads: Raise maxThreads in the ThreadPool section                   -->
18<!--           if you have a high-traffic site and get a lot of warnings.      -->
19<!--   * Uncomment the addWebApplications section to use to enable             -->
20<!--           war files placed in the webapps/ dir.                           -->
21<!--   * Uncomment the line to allow Jetty to follow symlinks                  -->
22<!--                                                                           -->
23<!-- I2P uses Jetty 9. If you need web server features not found               -->
24<!-- in Jetty 9, you may install and run Jetty 7 or 8 in a different JVM       -->
25<!-- or run any other web server such as Apache. If you do run another web     -->
26<!-- server instead, be sure and disable the Jetty 9 server for your           -->
27<!-- eepsite on http://127.0.0.1:7657/configclients.jsp .                      -->
28<!--                                                                           -->
29<!-- Jetty now uses the I2P logging system rather than wrapper.log.            -->
30<!-- Use the log override org.eclipse.jetty.server.Server to adjust the log level.  -->
31<!--                                                                           -->
32<!-- Note that the XML encoding for this file is UTF-8.                        -->
33<!--                                                                           -->
34<!-- If you have a 'split' directory installation, with configuration          -->
35<!-- files in ~/.i2p (Linux), %APPDATA%\I2P (Windows),                         -->
36<!-- or /Users/(user)/Library/Application Support/i2p (Mac), be sure to        -->
37<!-- edit the file in the configuration directory, NOT the install directory.  -->
38<!-- When running as a Linux daemon, the configuration directory is            -->
39<!-- /var/lib/i2p and the install directory is /usr/share/i2p .                -->
40<!-- When running as a Windows service,                                        -->
41<!-- the configuration directory is \ProgramData\i2p                           -->
42<!-- and the install directory is \Program Files\i2p .                         -->
43<!--                                                                           -->
44<!-- ========================================================================= -->
45
46<!-- ========================================================================= -->
47<!-- Configure the Jetty Server                                                -->
48<!--                                                                           -->
49<!-- Documentation of this file format can be found at:                        -->
50<!-- http://www.eclipse.org/jetty/documentation/current/jetty-xml-config.html  -->
51<!--                                                                           -->
52<!-- ========================================================================= -->
53
54
55<Configure id="Server" class="org.eclipse.jetty.server.Server">
56
57    <!-- =========================================================== -->
58    <!-- Server Thread Pool                                          -->
59    <!-- =========================================================== -->
60    <Arg>
61
62      <!-- PICK ONE -->
63
64      <!--
65           Recommended.
66           Two threads are used for the Connector and Acceptor.
67           Concurrent requests above maxThreads + queue size - 2 will be rejected and logged.
68           Due to the way QTP works, queue size should be larger than maxThreads.
69           Increase all values for high-traffic eepsites.
70
71           ref:
72           https://wiki.eclipse.org/Jetty/Howto/High_Load
73           http://trac.i2p2.i2p/ticket/1395
74       -->
75      <New class="org.eclipse.jetty.util.thread.QueuedThreadPool">
76        <Arg type="int">20</Arg>     <!-- maxThreads, overridden below -->
77        <Arg type="int">3</Arg>      <!-- minThreads, overridden below -->
78        <Arg type="int">60000</Arg>  <!-- maxIdleTimeMs, overridden below -->
79        <Arg>
80           <New class="java.util.concurrent.LinkedBlockingQueue">
81              <Arg type="int">40</Arg>
82           </New>
83        </Arg>
84        <Set name="minThreads">3</Set>
85        <Set name="maxThreads">20</Set>
86        <Set name="idleTimeout">60000</Set>
87        <Set name="daemon">true</Set>
88        <Set name="name">Eepsite Jetty</Set>
89      </New>
90    </Arg>
91
92
93
94    <!-- =========================================================== -->
95    <!-- Set connectors                                              -->
96    <!-- =========================================================== -->
97    <!-- One of each type!                                           -->
98    <!-- =========================================================== -->
99
100    <!-- Use this connector for many frequently idle connections
101         and for threadless continuations.
102         Not recommended on Java 5 - comment this out, and uncomment the
103         SocketConnector below.
104         Do not use for gij or JamVM - comment this out, and uncomment the
105         SocketConnector below.
106    -->   
107    <Call name="addConnector">
108      <Arg>
109          <New class="org.eclipse.jetty.server.ServerConnector">
110            <Arg><Ref id="Server" /></Arg>
111            <Arg type="int">1</Arg>     <!-- number of acceptors -->
112            <Arg type="int">0</Arg>     <!-- default number of selectors -->
113            <Arg>
114              <Array type="org.eclipse.jetty.server.ConnectionFactory">    <!-- varargs so we need an array -->
115                <Item>
116                  <New class="org.eclipse.jetty.server.HttpConnectionFactory">
117                    <Arg>
118                      <New class="org.eclipse.jetty.server.HttpConfiguration">
119                        <Set name="sendServerVersion">false</Set>
120                        <Set name="sendDateHeader">true</Set>
121                      </New>
122                    </Arg>
123                  </New>
124                </Item>
125              </Array>
126            </Arg>
127            <Set name="host">127.0.0.1</Set>
128            <Set name="port">7658</Set>
129            <Set name="idleTimeout">600000</Set>
130          </New>
131      </Arg>
132    </Call>
133
134    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
135    <!-- To add a HTTPS SSL listener                                     -->
136    <!-- see jetty-ssl.xml to add an ssl connector. use                  -->
137    <!-- To enable this change clients.config args to be:                -->
138    <!--                                                                 -->
139    <!--   clientApp3.args=etc/jetty.xml etc/jetty-ssl.xml               -->
140    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
141
142    <!-- =========================================================== -->
143    <!-- Set up global session ID manager                            -->
144    <!-- =========================================================== -->
145    <!--
146    <Set name="sessionIdManager">
147      <New class="org.eclipse.jetty.server.session.HashSessionIdManager">
148        <Set name="workerName">node1</Set>
149      </New>
150    </Set>
151    -->
152
153    <!-- =========================================================== -->
154    <!-- Set handler Collection Structure                            --> 
155    <!-- =========================================================== -->
156    <Set name="handler">
157      <New id="Handlers" class="org.eclipse.jetty.server.handler.HandlerCollection">
158        <Set name="handlers">
159         <Array type="org.eclipse.jetty.server.Handler">
160           <Item>
161             <New id="Contexts" class="org.eclipse.jetty.server.handler.ContextHandlerCollection"/>
162           </Item>
163           <Item>
164             <New id="DefaultHandler" class="org.eclipse.jetty.server.handler.DefaultHandler"/>
165           </Item>
166           <Item>
167             <New id="RequestLog" class="org.eclipse.jetty.server.handler.RequestLogHandler"/>
168           </Item>
169         </Array>
170        </Set>
171      </New>
172    </Set>
173
174    <!-- =============================================================== -->
175    <!-- Create the deployment manager                                   -->
176    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
177    <!-- The deplyment manager handles the lifecycle of deploying web    -->
178    <!-- applications. Apps are provided by instances of the             -->
179    <!-- AppProvider interface.  Typically these are provided by         -->
180    <!-- one or more of:                                                 -->
181    <!--   jetty-webapps.xml       - monitors webapps for wars and dirs  -->
182    <!--   jetty-contexts.xml      - monitors contexts for context xml   -->
183    <!--   jetty-templates.xml     - monitors contexts and templates     -->
184    <!-- =============================================================== -->
185    <Call name="addBean">
186      <Arg>
187        <New id="DeploymentManager" class="org.eclipse.jetty.deploy.DeploymentManager">
188          <Set name="contexts">
189            <Ref id="Contexts" />
190          </Set>
191          <Call name="setContextAttribute">
192            <Arg>org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern</Arg>
193            <Arg>.*/.*jsp-api-[^/]*\.jar$|.*/.*jsp-[^/]*\.jar$|.*/.*taglibs[^/]*\.jar$</Arg>
194          </Call>
195        </New>
196      </Arg>
197    </Call>
198
199    <!-- =========================================================== -->
200    <!-- Configure the context deployer                              -->
201    <!-- A context deployer will deploy contexts described in        -->
202    <!-- configuration files discovered in a directory.              -->
203    <!-- The configuration directory can be scanned for hot          -->
204    <!-- deployments at the configured scanInterval.                 -->
205    <!--                                                             -->
206    <!-- This deployer is configured to deploy contexts configured   -->
207    <!-- in the $JETTY_HOME/contexts directory                       -->
208    <!--                                                             -->
209    <!-- =========================================================== -->
210    <Ref id="DeploymentManager">
211      <Call name="addAppProvider">
212        <Arg>
213          <New class="org.eclipse.jetty.deploy.providers.WebAppProvider">
214            <Set name="monitoredDirName">./eepsite/contexts</Set>
215            <Set name="scanInterval">120</Set>
216          </New>
217        </Arg>
218      </Call>
219    </Ref>
220
221    <!-- =========================================================== -->
222    <!-- Configure the webapp deployer.                              -->
223    <!-- A webapp  deployer will deploy standard webapps discovered  -->
224    <!-- in a directory at startup, without the need for additional  -->
225    <!-- configuration files.    It does not support hot deploy or   -->
226    <!-- non standard contexts (see ContextDeployer above).          -->
227    <!--                                                             -->
228    <!-- This deployer is configured to deploy webapps from the      -->
229    <!-- $JETTY_HOME/webapps directory                               -->
230    <!--                                                             -->
231    <!-- Normally only one type of deployer need be used.            -->
232    <!--                                                             -->
233    <!-- =========================================================== -->
234    <Ref id="DeploymentManager">
235      <Call id="webappprovider" name="addAppProvider">
236        <Arg>
237          <New class="org.eclipse.jetty.deploy.providers.WebAppProvider">
238            <Set name="monitoredDirName">./eepsite/webapps</Set>
239            <Set name="parentLoaderPriority">false</Set>
240            <Set name="extractWars">false</Set>
241            <Set name="defaultsDescriptor">./eepsite/etc/webdefault.xml</Set>
242          </New>
243        </Arg>
244      </Call>
245    </Ref>
246
247    <!-- ===================== -->
248    <!-- DefaultHandler config -->
249    <!-- http://stackoverflow.com/questions/4202275/how-to-prevent-jetty-from-showing-context-related-information -->
250    <!-- ===================== -->
251    <Ref id="DefaultHandler">
252      <Set name="showContexts">false</Set>
253    </Ref>
254
255    <!-- =========================================================== -->
256    <!-- Configure Authentication Realms                             -->
257    <!-- Realms may be configured for the entire server here, or     -->
258    <!-- they can be configured for a specific web app in a context  -->
259    <!-- configuration (see $(jetty.home)/contexts/test.xml for an   -->
260    <!-- example).                                                   -->
261    <!-- =========================================================== -->
262  <!-- UNCOMMENT TO ACTIVATE
263    <Set name="UserRealms">
264      <Array type="org.eclipse.jetty.security.LoginService">
265        <Item>
266          <New class="org.eclipse.jetty.security.HashLoginService">
267            <Set name="name">Test Realm</Set>
268            <Set name="config">./eepsite/etc/realm.properties</Set>
269            <Set name="refreshInterval">0</Set>
270          </New>
271        </Item>
272      </Array>
273    </Set>
274  -->
275
276    <!-- =========================================================== -->
277    <!-- Configure Request Log                                       -->
278    <!-- Request logs  may be configured for the entire server here, -->
279    <!-- or they can be configured for a specific web app in a       -->
280    <!-- contexts configuration (see $(jetty.home)/contexts/test.xml -->
281    <!-- for an example).                                            -->
282    <!-- =========================================================== -->
283    <Ref id="RequestLog">
284      <Set name="requestLog">
285        <New id="RequestLogImpl" class="net.i2p.jetty.I2PRequestLog">
286          <Set name="filename">./eepsite/logs/yyyy_mm_dd.request.log</Set>
287          <Set name="filenameDateFormat">yyyy_MM_dd</Set>
288          <Set name="retainDays">90</Set>
289          <Set name="append">true</Set>
290          <Set name="extended">false</Set>
291          <Set name="logCookies">false</Set>
292          <Set name="LogTimeZone">GMT</Set>
293          <!-- False for b32 logging. True for b64 logging. Default false -->
294          <Set name="b64">false</Set>
295        </New>
296      </Set>
297    </Ref>
298
299    <!-- =========================================================== -->
300    <!-- extra options                                               -->
301    <!-- =========================================================== -->
302    <Set name="stopAtShutdown">true</Set>
303    <Set name="stopTimeout">1000</Set>
304
305</Configure>
Note: See TracBrowser for help on using the repository browser.