mod_cache.xml revision e2c93125be350d68b887588471746a87c89f9d6b
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<?xml version="1.0"?>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<!DOCTYPE modulesynopsis SYSTEM "/style/modulesynopsis.dtd">
e942c741056732f50da2074b36fe59805d370650slive<?xml-stylesheet type="text/xsl" href="/style/manual.en.xsl"?>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<modulesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>mod_cache</name>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<description>Content cache keyed to URIs.</description>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<status>Experimental</status>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<sourcefile>mod_cache.c</sourcefile>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<identifier>cache_module</identifier>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<summary>
88c775368960b64afcdfd93a812f466a109746baerikabele <note type="warning">
88c775368960b64afcdfd93a812f466a109746baerikabele This module is experimental. Documentation is still under development...
88c775368960b64afcdfd93a812f466a109746baerikabele </note>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>mod_cache implements an RFC 2616 compliant HTTP content
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard cache that can be used to cache either local or proxied content.
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard mod_cache requires the services of one or more storage
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard management modules. Two storage management modules are included in
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard the base Apache distribution:</p>
3ec4de296cf8eb31d8a59811b58720efafccf109patrikj <dl>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <dt><em><module>mod_disk_cache</module></em></dt>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <dd>implements a disk based storage manager for use with <module>mod_proxy</module></dd>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <dt><em><module>mod_mem_cache</module></em></dt>
3ec4de296cf8eb31d8a59811b58720efafccf109patrikj <dd>implements an in-memory based storage manager. mod_mem_cache
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard can be configured to operate in two modes: caching open file
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard descriptors or caching objects in heap storage. <em><module>mod_mem_cache</module></em>
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard is most useful when used to cache locally generated content or to cache
3ec4de296cf8eb31d8a59811b58720efafccf109patrikj backend server content for mod_proxy configured for ProxyPass (aka <em>reverse proxy</em>)</dd>
3ec4de296cf8eb31d8a59811b58720efafccf109patrikj </dl>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>Content stored and retrived keyed to the URL. Content with
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard access protections is not cached.</p>
88c775368960b64afcdfd93a812f466a109746baerikabele</summary>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
88c775368960b64afcdfd93a812f466a109746baerikabele<section id="related"><title>Related Modules and Directives</title>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <related>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <modulelist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <module>mod_disk_cache</module>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <module>mod_mem_cache</module>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </modulelist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directivelist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheRoot</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheGcInterval</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheDirLevels</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheDirLength</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheExpiryCheck</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheMinFileSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheMaxFileSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheTimeMargin</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheGcDaily</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheGcUnused</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheGcClean</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_disk_cache">CacheGcMemUsage</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_mem_cache">MCacheSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_mem_cache">MCacheMaxObjectCount</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_mem_cache">MCacheMinObjectSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_mem_cache">MCacheMaxObjectSize</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <directive module="mod_mem_cache">MCacheRemovalAlgorithm</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </directivelist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </related>
88c775368960b64afcdfd93a812f466a109746baerikabele</section>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<section><title>Sample Configuration</title>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<example><title>Sample httpd.conf</title>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard# <br />
7d2c654eb12a943bb763fc218337545e543ac2eberikabele# Sample Cache Configuration <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard# <br />
7d2c654eb12a943bb763fc218337545e543ac2eberikabeleLoadModule cache_module modules/mod_cache.so <br />
7d2c654eb12a943bb763fc218337545e543ac2eberikabele&lt;IfModule mod_cache.c&gt; <br />
7d2c654eb12a943bb763fc218337545e543ac2eberikabele<br />
7d2c654eb12a943bb763fc218337545e543ac2eberikabele#LoadModule disk_cache_module modules/mod_disk_cache.so <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard &lt;IfModule mod_disk_cache.c&gt; <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheRoot c:/cacheroot <br />
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard CacheSize 256 <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheEnable disk / <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheDirLevels 5 <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheDirLength 3 <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard &lt;/IfModule&gt; <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<p />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard LoadModule mem_cache_module modules/mod_mem_cache.so <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard &lt;IfModule mod_mem_cache.c&gt; <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard MCacheEnable mem / <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard MCacheSize 4096 <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard MCacheMaxObjectCount 100 <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard MCacheMinObjectSize 1 <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard MCacheMaxObjectSize 2048 <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard &lt;/IfModule&gt; <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<p />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard&lt;/IfModule&gt; <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</section>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheEnable</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>Enable caching specified URLs in a specified storage manager</description>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<syntax>CacheEnable <em>cache_type </em><em> url-string</em></syntax>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>The <directive>CacheEnable</directive> directive instructs
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard mod_cache to cache urls at or below <em>url-string</em>.
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard The cache store is specified with the <em>cache_type</em> argument.
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <em>cache_type </em> <em> mem</em> instructs mod_cache to use the
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard in-memory cache storage manager implemented by <em>mod_mem_cache</em>.
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <em>cache_type </em> <em> disk</em> instructs mod_cache to use the
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard cache storage manager implemented by <em>mod_disk_cache </em>. </p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheEnable disk / <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard CacheEnable mem /manual <br />
3e5f26422e7931e8838f3c844adc4282ef269cdfstoddard CacheEnable fd /images <br />
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheDisable</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>Disable caching of specified URLs by specified storage manager</description>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<syntax>CacheDisable <em>cache_type </em> <em> url-string</em></syntax>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>The <directive>CacheDisable</directive> directive instructs
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard mod_cache to <em>not</em> cache urls at or above <em>url-string</em>.</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<example><title>Example</title>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheDisable disk /local_files
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheMaxExpire</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>The maximum time in seconds to cache a document</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheMaxExpire <em>seconds</em></syntax>
88c775368960b64afcdfd93a812f466a109746baerikabele<default>CacheMaxExpire 86400 (one day)</default>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <p>The maximum time in seconds to cache a document. The <directive>CacheMaxExpire</directive>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard takes precedence over the <em>Expire</em> field from the header.</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheMaxExpire 604800
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard </example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheDefaultExpire</name>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheDefaultExpire <em>seconds</em></syntax>
88c775368960b64afcdfd93a812f466a109746baerikabele<default>CacheDefaultExpire 3600 (one hour)</default>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <p>The default time in seconds to cache a document if the page does not have
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard an expiry date in the <em>Expires</em> field.</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheDefaultExpire 86400
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard </example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheIgnoreNoLastMod</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>Ignore responses where there is no Last Modified Header</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheIgnoreNoLastMod</syntax>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>Ignore responses where there is no Last Modified Header</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheIgnoreNoLastMod
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard </example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheIgnoreCacheControl</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>Ignore requests from the client for uncached content</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheIgnoreCacheControl</syntax>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>Ignore requests from the client for uncached content</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheIgnoreNoLastMod
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard </example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<name>CacheLastModifiedFactor</name>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<description>The factor used to estimate the Expires date from the LastModified date</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheLastModifiedFactor <em>float</em></syntax>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<default>CacheLastModifiedFactor 0.1</default>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<contextlist><context>server config</context></contextlist>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard<usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <p>The factor used to estimate the Expires date from the LastModified date.</p>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard <example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard CacheLastModifiedFactor
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard </example>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</usage>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</directivesynopsis>
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<directivesynopsis>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<name>CacheForceCompletion</name>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<description>Percentage of download to arrive for the cache to force complete transfert</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheLastModifiedFactor <em>Percentage</em></syntax>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<default>CacheLastModifiedFactor 60</default>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<contextlist><context>server config</context></contextlist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<usage>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <p>Percentage of download to arrive for the cache to force complete transfert.</p>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <example>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard CacheForceCompletion
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </example>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<note type="warning">
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddardThis feature is currently <em>not</em> implemented.
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard</note>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </usage>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </directivesynopsis>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<directivesynopsis>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<name>CacheForceCompletion</name>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<description>Percentage of download to arrive for the cache to force complete transfer</description>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<syntax>CacheLastModifiedFactor <em>Percentage</em></syntax>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<default>CacheLastModifiedFactor 60</default>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<contextlist><context>server config</context></contextlist>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<usage>
e2c93125be350d68b887588471746a87c89f9d6bbrianp <p>Percentage of download to arrive for the cache to force complete transfer.</p>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard <example>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard CacheForceCompletion
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard </example>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard<note type="warning">
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddardThis feature is currently <em>not</em> implemented.
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard</note>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard</usage>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard</directivesynopsis>
1e5b300cc68389a18fe3762b1b980b0c86712ba1stoddard
e2c93125be350d68b887588471746a87c89f9d6bbrianp<directivesynopsis>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<name>CacheMaxStreamingBuffer</name>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<description>Maximum amount of a streamed response to buffer in memory before declaring the response uncacheable</description>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<syntax>CacheMaxStreamingBuffer <em>size_in_bytes</em></syntax>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<default>CacheMaxStreamingBuffer 0</default>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<contextlist><context>server config</context></contextlist>
e2c93125be350d68b887588471746a87c89f9d6bbrianp
e2c93125be350d68b887588471746a87c89f9d6bbrianp<usage>
e2c93125be350d68b887588471746a87c89f9d6bbrianp <p>Maximum number of bytes of a streamed response (i.e., a response where the entire content is not available all at once, such as a proxy or CGI response) to buffer before deciding if the response is cacheable. By default, a streamed response will <em>not</em> be cached unless it has a Content-Length header. The reason for this is to avoid using a large amount of memory to buffer a partial response that might end up being too large to fit in the cache anyway. To enable caching of streamed responses, use CacheMaxStreamingBuffer to specify the maximum amount of buffer space to use per request.</p>
e2c93125be350d68b887588471746a87c89f9d6bbrianp<p>Note: Using a nonzero value for CacheMaxStreamingBuffer will not delay the transmission of the response to the client. As soon as mod_cache copies a
e2c93125be350d68b887588471746a87c89f9d6bbrianpblock of streamed content into a buffer, it sends the block on to the next
e2c93125be350d68b887588471746a87c89f9d6bbrianpoutput filter for delivery to the client.</p>
e2c93125be350d68b887588471746a87c89f9d6bbrianp
e2c93125be350d68b887588471746a87c89f9d6bbrianp <example>
e2c93125be350d68b887588471746a87c89f9d6bbrianp # Enable caching of streamed responses up to 64KB:
e2c93125be350d68b887588471746a87c89f9d6bbrianp CacheMaxStreamingBuffer 65536
e2c93125be350d68b887588471746a87c89f9d6bbrianp </example>
e2c93125be350d68b887588471746a87c89f9d6bbrianp</usage>
e2c93125be350d68b887588471746a87c89f9d6bbrianp</directivesynopsis>
e2c93125be350d68b887588471746a87c89f9d6bbrianp
721fdd19e2abef2e8dc46eb5c022ef14efe3367estoddard</modulesynopsis>