source: installer/resources/eepsite/jetty.xml @ 57b794f

Last change on this file since 57b794f was 57b794f, checked in by zzz <zzz@…>, 7 years ago
  • Jetty logging: Fix logging using I2PLogger class; log ignored messages at debug level
  • Property mode set to 100644
File size: 15.5 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<!-- ========================================================================= -->
5<!-- This file configures the Jetty server.                                    -->
6<!-- All changes require a restart of I2P.                                     -->
7<!--                                                                           -->
8<!-- Commonly changed settings:                                                -->
9<!--   * host: Change 127.0.0.1 to 0.0.0.0 in the addListener section          -->
10<!--           to access the server directly (bypassing i2p)                   -->
11<!--           from other computers.                                           -->
12<!--   * port: Default 7658 in the addConnector section                         -->
13<!--   * docroot: Change the ResourceBase in the contexts/base-context.xml file -->
14<!--           to serve files from a different location.                       -->
15<!--   * threads: Raise maximumPoolSize in the ThreadPool section              -->
16<!--           if you have a high-traffic site and get a lot of warnings.      -->
17<!--   * Uncomment the addWebApplications section to use to enable             -->
18<!--           war files placed in the webapps/ dir.                           -->
19<!--   * Uncomment the line to allow Jetty to follow symlinks                  -->
20<!--                                                                           -->
21<!-- I2P uses Jetty 7. If you need web server features not found               -->
22<!-- in Jetty 7, you may install and run Jetty 7 or 8 in a different JVM       -->
23<!-- or run any other web server such as Apache. If you do run another web     -->
24<!-- server instead, be sure and disable the Jetty 6 server for your           -->
25<!-- eepsite on http://127.0.0.1:7657/configclients.jsp .                      -->
26<!--                                                                           -->
27<!-- Jetty now uses the I2P logging system rather than wrapper.log.            -->
28<!-- Use the log override org.eclipse.jetty.server.Server to adjust the log level.  -->
29<!--                                                                           -->
30<!-- Note that the XML encoding for this file is UTF-8.                        -->
31<!--                                                                           -->
32<!-- If you have a 'split' directory installation, with configuration          -->
33<!-- files in ~/.i2p (Linux) or %APPDATA%\I2P (Windows), be sure to            -->
34<!-- edit the file in the configuration directory, NOT the install directory.  -->
35<!--                                                                           -->
36<!-- ========================================================================= -->
37
38<!-- =============================================================== -->
39<!-- Configure the Jetty Server                                      -->
40<!--                                                                 -->
41<!-- Documentation of this file format can be found at:              -->
42<!-- http://docs.codehaus.org/display/JETTY/jetty.xml                -->
43<!--                                                                 -->
44<!-- =============================================================== -->
45
46
47<Configure id="Server" class="org.eclipse.jetty.server.Server">
48
49    <!-- =========================================================== -->
50    <!-- Server Thread Pool                                          -->
51    <!-- =========================================================== -->
52    <Set name="ThreadPool">
53
54      <!-- PICK ONE -->
55
56      <!-- If you don't have or want threadpool
57           Requests above the max will be queued
58       -->
59     <!--
60      <New class="org.eclipse.jetty.util.thread.QueuedThreadPool">
61        <Set name="minThreads">1</Set>
62        <Set name="maxThreads">16</Set>
63        <Set name="lowThreads">2</Set>
64      </New>
65     -->
66
67      <!-- Optional Java 5 bounded threadpool with job queue
68           Requests above the max will be rejected and logged.
69           High-traffic sites should increase maximumPoolSize.
70           TODO: would be nice to use the 5-arg constructor but
71                 how do you use an Enum as the TimeUnit argument?
72           Alternatively, make a custom class where we can
73           set the thread name, set daemon, etc.
74           See RouterConsoleRunner.
75       -->
76      <New class="org.eclipse.jetty.util.thread.ExecutorThreadPool">
77        <!-- corePoolSize (must be at least 3, increase if Jetty hangs) -->
78        <Arg type="int">4</Arg>
79        <!-- maximumPoolSize -->
80        <Arg type="int">20</Arg>
81        <!-- keepAliveTime (milliseconds) -->
82        <Arg type="long">60000</Arg>
83      </New>
84    </Set>
85
86
87
88    <!-- =========================================================== -->
89    <!-- Set connectors                                              -->
90    <!-- =========================================================== -->
91    <!-- One of each type!                                           -->
92    <!-- =========================================================== -->
93
94    <!-- Use this connector for many frequently idle connections
95         and for threadless continuations.
96         Not recommended on Java 5 - comment this out, and uncomment the
97         SocketConnector below.
98         Do not use for gij or JamVM - comment this out, and uncomment the
99         SocketConnector below.
100    -->   
101    <Call name="addConnector">
102      <Arg>
103          <New class="org.eclipse.jetty.server.nio.SelectChannelConnector">
104            <Set name="host">127.0.0.1</Set>
105            <Set name="port">7658</Set>
106            <Set name="maxIdleTime">60000</Set>
107            <Set name="Acceptors">1</Set>
108            <Set name="statsOn">false</Set>
109            <Set name="confidentialPort">8443</Set>
110            <Set name="lowResourcesConnections">5000</Set>
111            <Set name="lowResourcesMaxIdleTime">5000</Set>
112            <Set name="useDirectBuffers">false</Set>
113          </New>
114      </Arg>
115    </Call>
116
117    <!-- Recommended to use this connector on Java 5, as
118         Jetty 6 and Java 5 NIO don't play well together.
119    -->
120    <!--
121    <Call name="addConnector">
122      <Arg>
123          <New class="org.eclipse.jetty.server.bio.SocketConnector">
124            <Set name="host">127.0.0.1</Set>
125            <Set name="port">7658</Set>
126            <Set name="maxIdleTime">60000</Set>
127            <Set name="Acceptors">1</Set>
128            <Set name="statsOn">false</Set>
129            <Set name="confidentialPort">8443</Set>
130          </New>
131      </Arg>
132    </Call>
133    -->
134
135    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
136    <!-- To add a HTTPS SSL listener                                     -->
137    <!-- see jetty-ssl.xml to add an ssl connector. use                  -->
138    <!-- To enable this change clients.config args to be:                -->
139    <!--                                                                 -->
140    <!--   clientApp3.args=etc/jetty.xml etc/jetty-ssl.xml               -->
141    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
142  <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
143  <!-- Add a HTTPS SSL listener on port 8443                               -->
144  <!--                                                                     -->
145  <!-- In the unlikely event you would want SSL support for your eepsite.  -->
146  <!-- You would need to generate a selfsigned certificate in a keystore   -->
147  <!-- in ~/.i2p/eepsite/keystore.ks, for example with the command line:   -->
148  <!--
149       keytool -genkey -storetype JKS -keystore ~/.i2p/eepsite/etc/keystore.ks -storepass changeit -alias console -dname CN=xyz123.eepsite.i2p.net,OU=Eepsite,O=I2P Anonymous Network,L=XX,ST=XX,C=XX -validity 3650 -keyalg DSA -keysize 1024 -keypass myKeyPassword
150   -->
151  <!-- Change the CN and key password in the example, of course.           -->
152  <!-- You wouldn't want to open this up to the regular internet,          -->
153  <!-- would you?? Untested and not recommended.                           -->
154  <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
155
156    <!-- =========================================================== -->
157    <!-- Set up global session ID manager                            -->
158    <!-- =========================================================== -->
159    <!--
160    <Set name="sessionIdManager">
161      <New class="org.eclipse.jetty.server.session.HashSessionIdManager">
162        <Set name="workerName">node1</Set>
163      </New>
164    </Set>
165    -->
166
167    <!-- =========================================================== -->
168    <!-- Set handler Collection Structure                            --> 
169    <!-- =========================================================== -->
170    <Set name="handler">
171      <New id="Handlers" class="org.eclipse.jetty.server.handler.HandlerCollection">
172        <Set name="handlers">
173         <Array type="org.eclipse.jetty.server.Handler">
174           <Item>
175             <New id="Contexts" class="org.eclipse.jetty.server.handler.ContextHandlerCollection"/>
176           </Item>
177           <Item>
178             <New id="DefaultHandler" class="org.eclipse.jetty.server.handler.DefaultHandler"/>
179           </Item>
180           <Item>
181             <New id="RequestLog" class="org.eclipse.jetty.server.handler.RequestLogHandler"/>
182           </Item>
183         </Array>
184        </Set>
185      </New>
186    </Set>
187
188    <!-- =============================================================== -->
189    <!-- Create the deployment manager                                   -->
190    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
191    <!-- The deplyment manager handles the lifecycle of deploying web    -->
192    <!-- applications. Apps are provided by instances of the             -->
193    <!-- AppProvider interface.  Typically these are provided by         -->
194    <!-- one or more of:                                                 -->
195    <!--   jetty-webapps.xml       - monitors webapps for wars and dirs  -->
196    <!--   jetty-contexts.xml      - monitors contexts for context xml   -->
197    <!--   jetty-templates.xml     - monitors contexts and templates     -->
198    <!-- =============================================================== -->
199    <Call name="addBean">
200      <Arg>
201        <New id="DeploymentManager" class="org.eclipse.jetty.deploy.DeploymentManager">
202          <Set name="contexts">
203            <Ref id="Contexts" />
204          </Set>
205          <Call name="setContextAttribute">
206            <Arg>org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern</Arg>
207            <Arg>.*/.*jsp-api-[^/]*\.jar$|.*/.*jsp-[^/]*\.jar$|.*/.*taglibs[^/]*\.jar$</Arg>
208          </Call>
209        </New>
210      </Arg>
211    </Call>
212
213    <!-- =========================================================== -->
214    <!-- Configure the context deployer                              -->
215    <!-- A context deployer will deploy contexts described in        -->
216    <!-- configuration files discovered in a directory.              -->
217    <!-- The configuration directory can be scanned for hot          -->
218    <!-- deployments at the configured scanInterval.                 -->
219    <!--                                                             -->
220    <!-- This deployer is configured to deploy contexts configured   -->
221    <!-- in the $JETTY_HOME/contexts directory                       -->
222    <!--                                                             -->
223    <!-- =========================================================== -->
224    <Ref id="DeploymentManager">
225      <Call name="addAppProvider">
226        <Arg>
227          <New class="org.eclipse.jetty.deploy.providers.ContextProvider">
228            <Set name="monitoredDirName">./eepsite/contexts</Set>
229            <Set name="scanInterval">120</Set>
230          </New>
231        </Arg>
232      </Call>
233    </Ref>
234
235    <!-- =========================================================== -->
236    <!-- Configure the webapp deployer.                              -->
237    <!-- A webapp  deployer will deploy standard webapps discovered  -->
238    <!-- in a directory at startup, without the need for additional  -->
239    <!-- configuration files.    It does not support hot deploy or   -->
240    <!-- non standard contexts (see ContextDeployer above).          -->
241    <!--                                                             -->
242    <!-- This deployer is configured to deploy webapps from the      -->
243    <!-- $JETTY_HOME/webapps directory                               -->
244    <!--                                                             -->
245    <!-- Normally only one type of deployer need be used.            -->
246    <!--                                                             -->
247    <!-- =========================================================== -->
248    <Ref id="DeploymentManager">
249      <Call id="webappprovider" name="addAppProvider">
250        <Arg>
251          <New class="org.eclipse.jetty.deploy.providers.WebAppProvider">
252            <Set name="monitoredDirName">./eepsite/webapps</Set>
253            <Set name="parentLoaderPriority">false</Set>
254            <Set name="extractWars">false</Set>
255            <Set name="defaultsDescriptor">./eepsite/etc/webdefault.xml</Set>
256          </New>
257        </Arg>
258      </Call>
259    </Ref>
260
261    <!-- =========================================================== -->
262    <!-- Configure Authentication Realms                             -->
263    <!-- Realms may be configured for the entire server here, or     -->
264    <!-- they can be configured for a specific web app in a context  -->
265    <!-- configuration (see $(jetty.home)/contexts/test.xml for an   -->
266    <!-- example).                                                   -->
267    <!-- =========================================================== -->
268  <!-- UNCOMMENT TO ACTIVATE
269    <Set name="UserRealms">
270      <Array type="org.eclipse.jetty.security.LoginService">
271        <Item>
272          <New class="org.eclipse.jetty.security.HashLoginService">
273            <Set name="name">Test Realm</Set>
274            <Set name="config">./eepsite/etc/realm.properties</Set>
275            <Set name="refreshInterval">0</Set>
276          </New>
277        </Item>
278      </Array>
279    </Set>
280  -->
281
282    <!-- =========================================================== -->
283    <!-- Configure Request Log                                       -->
284    <!-- Request logs  may be configured for the entire server here, -->
285    <!-- or they can be configured for a specific web app in a       -->
286    <!-- contexts configuration (see $(jetty.home)/contexts/test.xml -->
287    <!-- for an example).                                            -->
288    <!-- =========================================================== -->
289    <Ref id="RequestLog">
290      <Set name="requestLog">
291        <New id="RequestLogImpl" class="net.i2p.jetty.I2PRequestLog">
292          <Set name="filename">./eepsite/logs/yyyy_mm_dd.request.log</Set>
293          <Set name="filenameDateFormat">yyyy_MM_dd</Set>
294          <Set name="retainDays">90</Set>
295          <Set name="append">true</Set>
296          <Set name="extended">false</Set>
297          <Set name="logCookies">false</Set>
298          <Set name="LogTimeZone">GMT</Set>
299        </New>
300      </Set>
301    </Ref>
302
303    <!-- =========================================================== -->
304    <!-- extra options                                               -->
305    <!-- =========================================================== -->
306    <Set name="stopAtShutdown">true</Set>
307    <Set name="sendServerVersion">false</Set>
308    <Set name="sendDateHeader">true</Set>
309    <Set name="gracefulShutdown">1000</Set>
310
311</Configure>
Note: See TracBrowser for help on using the repository browser.