Scaling and configuring Content Delivery
Content Delivery (CD) roles delivers your content to your visitors. You can configure multiple CD instances to meet your scaling requirements.
Installation
Use the Sitecore Installation Framework (SIF) or the Sitecore Azure Toolkit (SAT) to install the Content Delivery (CD) role. Refer to the installation guide for your version of the platform for more information.
Scaling the Content Delivery role
The following table describes your options for scaling the Content Delivery (CD) role:
Scaling option |
Supported |
Notes |
---|---|---|
Combined instance |
No |
The Content Delivery role must not be combined with any other role in production. The CD role can only be combined with other roles in the following circumstances:
Note In a developer environment, all core roles can be combined into a single instance. This includes Content Management, Content Delivery, xDB Processing, xDB Reporting, and EXM Dispatch. This setup is not recommended in production. |
Standalone instance |
Yes |
|
High availability and failover |
Yes |
You can fail over to a passive instance or set up multiple active instances behind a load balancer. |
Horizontal scaling for load distribution |
Yes |
The CD role can be scaled horizontally into a load balanced content delivery cluster or across multiple data center to provide geographic scaling or data center level fail-over. In a scenario with multiple CD clusters, be aware of the following:
|
Clustering |
Yes |
You can set up multiple clusters of Content Delivery servers. Each cluster can have its own Web database. In 9.1 and later, Content Delivery does not require a connection to the Core database. Note If you want to use Sitecore's default user management to support extranet users, all Content Delivery instances must connect to a centrally located Security database. |
Performance tuning tasks
To improve the performance of your CD role, consider the following performance tuning options:
-
Use one or more dedicated CD instances to handle session expiration. This is supported by the Redis provider in 9.1 and earlier. In Sitecore 9.2 and later, all session state providers support this feature.
-
Tune session expiration.
-
Reduce the tracker's Reference Data Client API timeout. Reference Data service response time can affect CD response time.
-
High resource consumption by the Reference Data database may result in a slower response time from the Reference Data service and degrade Content Delivery performance. There is a patch available for Sitecore 9.0 - 9.2.
-
Reduce the tracker's xConnect Client API timeout. The xConnect Collection service response time can affect the CD response time. If you use the xConnect Client API in your own code, review timeout settings per request.
-
Set up a dedicated device to handle encryption/decryption of incoming requests.
-
Reduce request to the Reference Data service by implementing Reference Data dictionary caching.
-
Use a Media Library CDN.
Security configuration tasks
Redacting contact IP addresses
The CD role stores all incoming contact IP addresses in the InteractionFacets table in the xDB Collection database. You can choose to have the CD role redact these IP addresses by changing the value
attribute of the Analytics.RedactIpAddress
setting in the <wwwroot>\App_Config\Sitecore\Marketing.Tracking\Sitecore.Analytics.Tracking.config
file.
<configuration>
<sitecore>
<settings>
<setting name="Analytics.RedactIpAddress" value="false" />
</settings>
</sitecore>
</configuration>
The following table shows the results of setting the value
attribute to either true
or false
:
Value |
Result |
---|---|
|
All incoming contact IP addresses are stored in plain text. |
|
All incoming contact IP addresses are redacted, and empty IP addresses (0.0.0.0) are stored instead. Important You lose the ability to determine contact IP addresses if you configure this setting to |
Encrypting contact IP addresses
The CD role stores all incoming contact IP addresses in the xDB Reference Data database. The IP addresses are encrypted by the Sitecore.Analytics.Lookups.IpHashProvider
provider using the MD5 algorithm and a random security string (a salt) which you can specify in the <wwwroot>\App_Config\Sitecore\Marketing.Tracking\Sitecore.Analytics.Tracking.config
file.
<configuration>
<sitecore>
<geoIpManager defaultProvider="default">
<providers>
<add
name="default"
salt="<SALT STRING>"
type="Sitecore.Analytics.Lookups.IpHashProvider, Sitecore.Analytics" />
</providers>
</geoIpManager>
</sitecore>
</configuration>
We recommend that you always enter a salt string of at least six random characters. You must never change the salt string after deployment. If you do, future incoming contact IP addresses are encrypted differently, and you lose data integrity.
Sitecore provides a tool called Hash Stored IPs. You use this tool when you upgrade from a Sitecore version earlier than 8.1, where IP addresses were not hashed.
General configuration tasks
The following general configuration tasks apply to the Content Delivery role:
Default topologies and packages
The following tables list the topologies that include the Content Delivery role and how the role is packaged by default.
Sitecore Installation Framework
The Content Delivery role is available in the following default topologies for the Sitecore Installation Framework:
Topology |
Web Deploy Packages |
Description |
---|---|---|
XP Single |
|
Content Delivery is bundled with all other Core roles. Not recommended in a production environment. |
XP Scaled |
|
Standalone instance of Content Delivery. |
XM Scaled |
|
Standalone instance of Content Delivery. |
Sitecore Azure Toolkit
The Content Delivery role is available in the following default topologies for the Sitecore Azure Toolkit:
Topology |
Web Deploy Packages |
Description |
---|---|---|
XP Single |
|
Content Delivery is bundled with all other Core roles. Not recommended in a production environment. |
XP Scaled |
|
Standalone instance of Content Delivery. |
XM Scaled |
|
Standalone instance of Content Delivery. |
XM Single |
|
Content Delivery is bundled with Content Management. Not recommended in a production environment. |