Merge branch 'jetty-9.4.x'
This commit is contained in:
commit
92f3003f7b
|
@ -15,7 +15,7 @@
|
||||||
// ========================================================================
|
// ========================================================================
|
||||||
|
|
||||||
[[sessions-usecases]]
|
[[sessions-usecases]]
|
||||||
=== Use Cases
|
=== Session Use Cases
|
||||||
|
|
||||||
==== Clustering with a Sticky Load Balancer
|
==== Clustering with a Sticky Load Balancer
|
||||||
|
|
||||||
|
@ -58,3 +58,36 @@ For various reasons it might not be possible for the `SessionDataStore` to re-re
|
||||||
One scenario is that the session stores a serialized object in it's attributes, and after a redeployment there in an incompatible class change.
|
One scenario is that the session stores a serialized object in it's attributes, and after a redeployment there in an incompatible class change.
|
||||||
Using the setter `SessionCache.setRemoveUnloadableSessions(true)` will allow the `SessionDataStore` to delete the unreadable session from persistent storage.
|
Using the setter `SessionCache.setRemoveUnloadableSessions(true)` will allow the `SessionDataStore` to delete the unreadable session from persistent storage.
|
||||||
This can be useful from preventing the scavenger from continually generating errors on the same expired, but un-restorable, session.
|
This can be useful from preventing the scavenger from continually generating errors on the same expired, but un-restorable, session.
|
||||||
|
|
||||||
|
==== Configuring Sessions via Jetty XML
|
||||||
|
|
||||||
|
With the provided session modules, there is no need to configure a context xml or `jetty-web.xml` file for sessions.
|
||||||
|
That said, if a user wishes to configure sessions this way, it is possible using link:#jetty-xml-syntax[Jetty IoC XML format.]
|
||||||
|
|
||||||
|
Below is an example of how you could configure a the link:#configuring-sessions-file-system[`FileSessionDataStore`], but the same concept would apply to any of the *SessionDataStores discussed in this chapter:
|
||||||
|
|
||||||
|
[source, xml, subs="{sub-order}"]
|
||||||
|
----
|
||||||
|
<Configure class="org.eclipse.jetty.webapp.WebAppContext">
|
||||||
|
<Call id="sh" name="getSessionHandler">
|
||||||
|
<Set name="sessionCache">
|
||||||
|
<New class="org.eclipse.jetty.server.session.DefaultSessionCache">
|
||||||
|
<Arg><Ref id="sh"/></Arg>
|
||||||
|
<Set name="sessionDataStore">
|
||||||
|
<New class="org.eclipse.jetty.server.session.FileSessionDataStore">
|
||||||
|
<Set name="storeDir">/tmp/sessions</Set>
|
||||||
|
</New>
|
||||||
|
</Set>
|
||||||
|
</New>
|
||||||
|
</Set>
|
||||||
|
</Call>
|
||||||
|
</Configure>
|
||||||
|
----
|
||||||
|
|
||||||
|
The example above functions in either a `jetty-web.xml` file or a link:#using-basic-descriptor-files[context xml descriptor file.]
|
||||||
|
|
||||||
|
____
|
||||||
|
[NOTE]
|
||||||
|
If you explicitly configure the `SessionCache` and `SessionDataStore` for a `SessionHandler` in a context xml file or `jetty-web.xml` file, any session modules you already have enabled are ignored.
|
||||||
|
So, for example, if you had enabled the `session-store-gcloud module` for your sever, you could force a particular webapp to use the `FileSessionDataStore` by explicitly configuring it in either a context xml file or a `jetty-web.xml` file as shown above.
|
||||||
|
____
|
||||||
|
|
Loading…
Reference in New Issue