source: installer/resources/eepsite/jetty.xml @ 0c77f7a

Last change on this file since 0c77f7a was 0c77f7a, checked in by kytv <kytv@…>, 9 years ago

update comments to reflect that we're now using jetty6

  • Property mode set to 100644
File size: 13.3 KB
Line 
1<?xml version="1.0" encoding="UTF-8" ?> 
2<!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure 1.2//EN" "http://jetty.mortbay.org/configure_1_2.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. The included version of Jetty has         -->
12<!--           been patched to allow IPv6 addresses as well,                   -->
13<!--           enclosed in brackets e.g. [::1]                                 -->
14<!--   * port: Default 7658 in the addListener section                         -->
15<!--   * docroot: Change the ResourceBase in the addContext section            -->
16<!--           to serve files from a different location.                       -->
17<!--   * threads: Raise MinThreads and/or MaxThreads in the addListener 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 6.1.26. If you need web server features not found          -->
24<!-- in Jetty 6, 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 6 server for your           -->
27<!-- eepsite on http://127.0.0.1:7657/configclients.jsp .                      -->
28<!--                                                                           -->
29<!-- Jetty errors and warnings will appear in wrapper.log, check there         -->
30<!-- to diagnose problems.                                                     -->
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) or %APPDATA%\I2P (Windows), be sure to            -->
36<!-- edit the file in the configuration directory, NOT the install directory.  -->
37<!--                                                                           -->
38<!-- ========================================================================= -->
39
40<!-- =============================================================== -->
41<!-- Configure the Jetty Server                                      -->
42<!--                                                                 -->
43<!-- Documentation of this file format can be found at:              -->
44<!-- http://docs.codehaus.org/display/JETTY/jetty.xml                -->
45<!--                                                                 -->
46<!-- =============================================================== -->
47
48
49<Configure id="Server" class="org.mortbay.jetty.Server">
50
51    <!-- =========================================================== -->
52    <!-- Server Thread Pool                                          -->
53    <!-- =========================================================== -->
54    <Set name="ThreadPool">
55
56      <!-- PICK ONE -->
57
58      <!-- If you don't have or want threadpool
59           Requests above the max will be queued
60       -->
61     <!--
62      <New class="org.mortbay.thread.QueuedThreadPool">
63        <Set name="minThreads">1</Set>
64        <Set name="maxThreads">16</Set>
65        <Set name="lowThreads">2</Set>
66      </New>
67     -->
68
69      <!-- Optional Java 5 bounded threadpool with job queue
70           Requests above the max will be rejected
71           TODO: would be nice to use the 5-arg constructor but
72                 how do you use an Enum as the TimeUnit argument?
73           Alternatively, make a custom class where we can
74           set the thread name, set daemon, etc.
75           See RouterConsoleRunner.
76       -->
77      <New class="org.mortbay.thread.concurrent.ThreadPool">
78        <Arg type="int">0</Arg>
79        <Set name="corePoolSize">1</Set>
80        <Set name="maximumPoolSize">16</Set>
81      </New>
82    </Set>
83
84
85
86    <!-- =========================================================== -->
87    <!-- Set connectors                                              -->
88    <!-- =========================================================== -->
89    <!-- One of each type!                                           -->
90    <!-- =========================================================== -->
91
92    <!-- Use this connector for many frequently idle connections
93         and for threadless continuations.
94    -->   
95    <Call name="addConnector">
96      <Arg>
97          <New class="org.mortbay.jetty.nio.SelectChannelConnector">
98            <Set name="host">127.0.0.1</Set>
99            <Set name="port">7658</Set>
100            <Set name="maxIdleTime">60000</Set>
101            <Set name="Acceptors">1</Set>
102            <Set name="statsOn">false</Set>
103            <Set name="confidentialPort">8443</Set>
104            <Set name="lowResourcesConnections">5000</Set>
105            <Set name="lowResourcesMaxIdleTime">5000</Set>
106          </New>
107      </Arg>
108    </Call>
109
110    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
111    <!-- To add a HTTPS SSL listener                                     -->
112    <!-- see jetty-ssl.xml to add an ssl connector. use                  -->
113    <!-- To enable this change clients.config args to be:                -->
114    <!--                                                                 -->
115    <!--   clientApp3.args=etc/jetty.xml etc/jetty-ssl.xml               -->
116    <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
117  <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
118  <!-- Add a HTTPS SSL listener on port 8443                               -->
119  <!--                                                                     -->
120  <!-- In the unlikely event you would want SSL support for your eepsite.  -->
121  <!-- You would need to generate a selfsigned certificate in a keystore   -->
122  <!-- in ~/.i2p/eepsite/keystore.ks, for example with the command line:   -->
123  <!--
124       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
125   -->
126  <!-- Change the CN and key password in the example, of course.           -->
127  <!-- You wouldn't want to open this up to the regular internet,          -->
128  <!-- would you?? Untested and not recommended.                           -->
129  <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
130
131    <!-- =========================================================== -->
132    <!-- Set up global session ID manager                            -->
133    <!-- =========================================================== -->
134    <!--
135    <Set name="sessionIdManager">
136      <New class="org.mortbay.jetty.servlet.HashSessionIdManager">
137        <Set name="workerName">node1</Set>
138      </New>
139    </Set>
140    -->
141
142    <!-- =========================================================== -->
143    <!-- Set handler Collection Structure                            --> 
144    <!-- =========================================================== -->
145    <Set name="handler">
146      <New id="Handlers" class="org.mortbay.jetty.handler.HandlerCollection">
147        <Set name="handlers">
148         <Array type="org.mortbay.jetty.Handler">
149           <Item>
150             <New id="Contexts" class="org.mortbay.jetty.handler.ContextHandlerCollection"/>
151           </Item>
152           <Item>
153             <New id="DefaultHandler" class="org.mortbay.jetty.handler.DefaultHandler"/>
154           </Item>
155           <Item>
156             <New id="RequestLog" class="org.mortbay.jetty.handler.RequestLogHandler"/>
157           </Item>
158         </Array>
159        </Set>
160      </New>
161    </Set>
162   
163    <!-- =========================================================== -->
164    <!-- Configure the context deployer                              -->
165    <!-- A context deployer will deploy contexts described in        -->
166    <!-- configuration files discovered in a directory.              -->
167    <!-- The configuration directory can be scanned for hot          -->
168    <!-- deployments at the configured scanInterval.                 -->
169    <!--                                                             -->
170    <!-- This deployer is configured to deploy contexts configured   -->
171    <!-- in the $JETTY_HOME/contexts directory                       -->
172    <!--                                                             -->
173    <!-- =========================================================== -->
174    <Call name="addLifeCycle">
175      <Arg>
176        <New class="org.mortbay.jetty.deployer.ContextDeployer">
177          <Set name="contexts"><Ref id="Contexts"/></Set>
178          <Set name="configurationDir">./eepsite/contexts</Set>
179          <Set name="scanInterval">0</Set>
180        </New>
181      </Arg>
182    </Call>
183
184    <!-- =========================================================== -->
185    <!-- Configure the webapp deployer.                              -->
186    <!-- A webapp  deployer will deploy standard webapps discovered  -->
187    <!-- in a directory at startup, without the need for additional  -->
188    <!-- configuration files.    It does not support hot deploy or   -->
189    <!-- non standard contexts (see ContextDeployer above).          -->
190    <!--                                                             -->
191    <!-- This deployer is configured to deploy webapps from the      -->
192    <!-- $JETTY_HOME/webapps directory                               -->
193    <!--                                                             -->
194    <!-- Normally only one type of deployer need be used.            -->
195    <!--                                                             -->
196    <!-- =========================================================== -->
197    <Call name="addLifeCycle">
198      <Arg>
199        <New class="org.mortbay.jetty.deployer.WebAppDeployer">
200          <Set name="contexts"><Ref id="Contexts"/></Set>
201          <Set name="webAppDir">./eepsite/webapps</Set>
202          <Set name="parentLoaderPriority">false</Set>
203          <Set name="extract">true</Set>
204          <Set name="allowDuplicates">false</Set>
205          <Set name="defaultsDescriptor">./eepsite/etc/webdefault.xml</Set>
206        </New>
207      </Arg>
208    </Call>
209
210    <!-- =========================================================== -->
211    <!-- Configure Authentication Realms                             -->
212    <!-- Realms may be configured for the entire server here, or     -->
213    <!-- they can be configured for a specific web app in a context  -->
214    <!-- configuration (see $(jetty.home)/contexts/test.xml for an   -->
215    <!-- example).                                                   -->
216    <!-- =========================================================== -->
217  <!-- UNCOMMENT TO ACTIVATE
218    <Set name="UserRealms">
219      <Array type="org.mortbay.jetty.security.UserRealm">
220        <Item>
221          <New class="org.mortbay.jetty.security.HashUserRealm">
222            <Set name="name">Test Realm</Set>
223            <Set name="config">./eepsite/etc/realm.properties</Set>
224            <Set name="refreshInterval">0</Set>
225          </New>
226        </Item>
227      </Array>
228    </Set>
229  -->
230
231    <!-- =========================================================== -->
232    <!-- Configure Request Log                                       -->
233    <!-- Request logs  may be configured for the entire server here, -->
234    <!-- or they can be configured for a specific web app in a       -->
235    <!-- contexts configuration (see $(jetty.home)/contexts/test.xml -->
236    <!-- for an example).                                            -->
237    <!-- =========================================================== -->
238    <Ref id="RequestLog">
239      <Set name="requestLog">
240        <New id="RequestLogImpl" class="net.i2p.jetty.I2PRequestLog">
241          <Set name="filename">./eepsite/logs/yyyy_mm_dd.request.log</Set>
242          <Set name="filenameDateFormat">yyyy_MM_dd</Set>
243          <Set name="retainDays">90</Set>
244          <Set name="append">true</Set>
245          <Set name="extended">false</Set>
246          <Set name="logCookies">false</Set>
247          <Set name="LogTimeZone">GMT</Set>
248        </New>
249      </Set>
250    </Ref>
251
252    <!-- =========================================================== -->
253    <!-- extra options                                               -->
254    <!-- =========================================================== -->
255    <Set name="stopAtShutdown">true</Set>
256    <Set name="sendServerVersion">false</Set>
257    <Set name="sendDateHeader">true</Set>
258    <Set name="gracefulShutdown">1000</Set>
259
260</Configure>
Note: See TracBrowser for help on using the repository browser.