Invalidating Cached Pages From AEM invalidating-cached-pages-from-aem
When using Dispatcher with AEM, the interaction must be configured to ensure effective cache management. Depending on your environment, the configuration can also increase performance.
Setting up AEM User Accounts setting-up-aem-user-accounts
The default admin
user account is used to authenticate the replication agents that are installed by default. Create a dedicated user account for use with replication agents.
For more information, see the Configure Replication and Transport Users section of the AEM Security Checklist.
Invalidating Dispatcher Cache from the Authoring Environment invalidating-dispatcher-cache-from-the-authoring-environment
A replication agent on the AEM author instance sends a cache invalidation request to Dispatcher when a page is published. Dispatcher refreshes the file eventually in the cache as new content is published.
Use the following procedure to configure a replication agent on the AEM author instance. The configuration invalidates the Dispatcher cache upon page activation:
-
Open the AEM Tools console. (
https://localhost:4502/miscadmin#/etc
) -
Open the required replication agent below Tools/replication/Agents on author. You can use the Dispatcher Flush agent that is installed by default.
-
Click Edit, and in the Settings tab ensure that Enabled is selected.
-
(optional) To enable alias or vanity path invalidation requests select the Alias update option.
-
On the Transport tab, access Dispatcher by entering the URI.
If you are using the standard Dispatcher Flush agent, update the hostname and port; for example, https://<dispatcherHost>:<portApache>/dispatcher/invalidate.cache
Note: For Dispatcher Flush agents, the URI property is used only if you use path-based virtual host entries to differentiate between farms. You use this field to target the farm to invalidate. For example, farm #1 has a virtual host of
www.mysite.com/path1/*
and farm #2 has a virtual host ofwww.mysite.com/path2/*
. You can use a URL of/path1/invalidate.cache
to target the first farm and/path2/invalidate.cache
to target the second farm. For more information, see Using Dispatcher with Multiple Domains. -
Configure other parameters as required.
-
Click OK so you can activate the agent.
Alternatively, you can also access and configure the Dispatcher Flush agent from the AEM Touch UI.
For more details on how to enable access to vanity URLs, see Enabling Access To Vanity URLs.
There are two potential issues with this approach:
-
The Dispatcher must be reachable from the authoring instance. If your network (for example, the firewall) is configured such that access between the two is restricted, this situation may not be the case.
-
Publication and cache invalidation take place at the same time. Depending on the timing, a user may request a page just after it was removed from the cache, and just before the new page is published. AEM now returns the old page, and the Dispatcher caches it again. This situation is more of an issue for large sites.
Invalidating Dispatcher Cache from a Publishing Instance invalidating-dispatcher-cache-from-a-publishing-instance
Under certain circumstances, performance gains can be made by transferring cache management from the authoring environment to a publishing instance. It is then the publishing environment (not the AEM authoring environment) that sends a cache invalidation request to Dispatcher when a published page is received.
Such circumstances include:
- Preventing possible timing conflicts between AEM Dispatcher and the publish instance (see Invalidating Dispatcher cache from the Authoring Environment).
- The system includes several publishing instances that reside on high performance servers, and only one authoring instance.
A replication agent operating on the publish instance controls the Dispatcher flush. However, the configuration is made in the authoring environment and then transferred by activating the agent:
-
Open the AEM Tools console.
-
Open the required replication agent below Tools/replication/Agents on publish. You can use the Dispatcher Flush agent that is installed by default.
-
Click Edit, and in the Settings tab ensure that Enabled is selected.
-
(optional) To enable alias or vanity path invalidation requests select the Alias update option.
-
On the Transport tab, access Dispatcher by entering the needed URI.
If you are using the standard Dispatcher Flush agent, update the hostname and port; for example,http://<dispatcherHost>:<portApache>/dispatcher/invalidate.cache
Note: For Dispatcher Flush agents, the URI property is used only if you use path-based virtual host entries to differentiate between farms. You use this field to target the farm to invalidate. For example, farm #1 has a virtual host of
www.mysite.com/path1/*
and farm #2 has a virtual host ofwww.mysite.com/path2/*
. You can use a URL of/path1/invalidate.cache
to target the first farm and/path2/invalidate.cache
to target the second farm. For more information, see Using Dispatcher with Multiple Domains. -
Configure other parameters as required.
-
Log in to the publishing instance and validate the flush agent configuration. Also, make sure it is enabled.
-
Repeat for every publish instance affected.
After configuring, when you activate a page from author to publish, this agent initiates a standard replication. The log includes messages indicating requests coming from your publish server, similar to the following example:
<publishserver> 13:29:47 127.0.0.1 POST /dispatcher/invalidate.cache 200
Manually Invalidating the Dispatcher Cache manually-invalidating-the-dispatcher-cache
To invalidate (or flush) the Dispatcher cache without activating a page, you can issue an HTTP request to the Dispatcher. For example, you can create an AEM application that enables administrators or other applications to flush the cache.
The HTTP request causes the Dispatcher to delete specific files from the cache. Optionally, the Dispatcher then refreshes the cache with a new copy.
Delete cached files delete-cached-files
Issue an HTTP request that causes the Dispatcher to delete files from the cache. Dispatcher caches the files again only when it receives a client request for the page. Deleting cached files in this manner is appropriate for web sites that are not likely to receive simultaneous requests for the same page.
The HTTP request has the following form:
POST /dispatcher/invalidate.cache HTTP/1.1
CQ-Action: Activate
CQ-Handle: path-pattern
Content-Length: 0
Dispatcher flushes (deletes) the cached files and folders that have names that match the value of the CQ-Handler
header. For example, a CQ-Handle
of /content/geomtrixx-outdoors/en
matches the following items:
-
All files (of any file extension) named
en
in thegeometrixx-outdoors
directory -
Any directory named
_jcr_content
below theen
directory (which, if it exists, contains cached renderings of sub-nodes of the page)
All other files in the Dispatcher cache (or up to a particular level, depending on the /statfileslevel
setting) are invalidated by touching the .stat
file. This file鈥檚 last modification date is compared to the last modification date of a cached document and the document is re-fetched if the .stat
file is newer. See Invalidating Files by Folder Level for details.
Invalidation (that is, touching of .stat files) can be prevented by sending an additional Header CQ-Action-Scope: ResourceOnly
. This functionality can be used to flush particular resources. All without invalidating other parts of the cache, like JSON data. That data is dynamically created and requires regular flushing independent of the cache. For example, representing data that is obtained from a third-party system to display news, stock tickers, and so on.
Delete and recache files delete-and-recache-files
Issue an HTTP request that causes the Dispatcher to delete cached files, and immediately retrieve and recache the file. Delete and immediately re-cache files when web sites are likely to receive simultaneous client requests for the same page. Immediate recaching ensures that Dispatcher retrieves and caches the page only once, instead of once for each of the simultaneous client requests.
Note: Deleting and recaching files should be performed on the publishing instance only. When performed from the author instance, race conditions occur when attempts to recache resources occur before they have been published.
The HTTP request has the following form:
POST /dispatcher/invalidate.cache HTTP/1.1
CQ-Action: Activate
`Content-Type: text/plain
CQ-Handle: path-pattern
Content-Length: numchars in bodypage_path0
page_path1
...
page_pathn
The page paths to re-cache immediately are listed on separate lines in the message body. The value of CQ-Handle
is the path of a page that invalidates the pages to recache. (See the /statfileslevel
parameter of the Cache configuration item.) The following example HTTP request message deletes and recaches the /content/geometrixx-outdoors/en.html page
:
POST /dispatcher/invalidate.cache HTTP/1.1
CQ-Action: Activate
Content-Type: text/plain
CQ-Handle: /content/geometrixx-outdoors/en/men.html
Content-Length: 36
/content/geometrixx-outdoors/en.html
Example flush servlet example-flush-servlet
The following code implements a servlet that sends an invalidation request to Dispatcher. The servlet receives a request message that contains handle
and page
parameters. These parameters provide the value of the CQ-Handle
header and the path of the page to recache, respectively. The servlet uses the values to construct the HTTP request for Dispatcher.
When the servlet is deployed to the publish instance, the following URL causes the Dispatcher to delete the /content/geometrixx-outdoors/en.html page and then cache a new copy.
10.36.79.223:4503/bin/flushcache/html?page=/content/geometrixx-outdoors/en.html&handle=/content/geometrixx-outdoors/en/men.html
package com.adobe.example;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Service;
import org.apache.felix.scr.annotations.Property;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.servlets.SlingSafeMethodsServlet;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.apache.commons.httpclient.*;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.methods.StringRequestEntity;
@Component(metatype=true)
@Service
public class Flushcache extends SlingSafeMethodsServlet {
@Property(value="/bin/flushcache")
static final String SERVLET_PATH="sling.servlet.paths";
private Logger logger = LoggerFactory.getLogger(this.getClass());
public void doGet(SlingHttpServletRequest request, SlingHttpServletResponse response) {
try{
//retrieve the request parameters
String handle = request.getParameter("handle");
String page = request.getParameter("page");
//hard-coding connection properties is a bad practice, but is done here to simplify the example
String server = "localhost";
String uri = "/dispatcher/invalidate.cache";
HttpClient client = new HttpClient();
PostMethod post = new PostMethod("https://"+host+uri);
post.setRequestHeader("CQ-Action", "Activate");
post.setRequestHeader("CQ-Handle",handle);
StringRequestEntity body = new StringRequestEntity(page,null,null);
post.setRequestEntity(body);
post.setRequestHeader("Content-length", String.valueOf(body.getContentLength()));
client.executeMethod(post);
post.releaseConnection();
//log the results
logger.info("result: " + post.getResponseBodyAsString());
}
}catch(Exception e){
logger.error("Flushcache servlet exception: " + e.getMessage());
}
}
}