Five New Optimizely Certifications are Here! Validate your expertise and advance your career with our latest certification exams. Click here to find out more
Five New Optimizely Certifications are Here! Validate your expertise and advance your career with our latest certification exams. Click here to find out more
EPiServer CMO and EPiServer Commerce do not support mirroring. Also, content mirroring is not supported in cloud deployment such as Windows Azure Web Apps and EPiServer Digital Experience Cloud (DXC).
Mirroring can only be installed for CMS 7.5 (through Deployment Center). To use mirroring with the latest EPiServer version, install a CMS 7.5 site with mirroring, and then upgrade to the latest through NuGet. There is no NuGet package available for the content mirroring functionality (it is installed as a separate service in a virtual directory on the server).
A mirroring job is normally done between two sites. This means that two sites probably have to be installed, one as a source site and one as a target site. Each site can be used as a source site or a target site regardless of the purpose from the beginning.
The installation package for EPiServer contains a setup file (setup.exe) that installs the Deployment Center and EPiServer CMS on the machine. This has to be done to be able to install Mirroring. Alternatively, EPiServerShared.msi and EPiServerCMS.msi can be run instead of the setup file.
Install mirroring on a new website as follows:
To be able to install Mirroring on an existing EPiServer CMS site, the site must be running on the same version as the mirroring DLL (EPiServer.MirroringService.dll).
Install mirroring on an existing website as follows:
Create a page that will act as the root page for the mirrored pages on the target site in the EPiServer CMS editorial interface. It is also possible to use an existing page as the mirroring root page.
Create and edit channels on the source site for mirroring in the EPiServer CMS administrative interface, see the section about configuring mirroring in the EPiServer CMS User Guide.
Start the mirroring process manually or automatically as a scheduled job in the EPiServer CMS administrative interface, see the section about running the mirroring service scheduled job in the EPiServer CMS User Guide.
To change the security credentials that are used when a Mirroring job is run, open the web.config file for the source mirroring application. Locate the episerverMirroring element in the configuration file and change the credentials in the MirroringTransferServer provider.
<episerverMirroring>
<mirroringTransfer defaultProvider="MirroringTransferServer">
<providers>
<add
defaultEndpointName="mirroringTargetEndPoint"
numberOfPagesInPackage="500"
numberOfFilesInPackage="100"
destinationPath="c:\temp\mirroring\"
chunkSize="4194304"
name="MirroringTransferServer"
type="EPiServer.MirroringService.MirroringTransferProtocol.WCF.MirroringTransferClient,EPiServer.Enterprise"
username="XXXX"
password=""
domain="ep" />
sourceConnectionStringName="" />
destinationConnectionStringName="" />
</providers>
</mirroringTransfer>
<mirroringMonitoring offlineLoggningEnabled="true" offlineLogPath="Path to offline log"/>
</episerverMirroring>
Configuration | Description |
---|---|
Changing chunk size | By default, the chunk size of the data sent between the machines is set to 4194304 bytes. This can be changed by changing this value in the provider attributes. |
Changing temporary folder | When data is sent between the machines, temporary files are stored in a location that can be modified in the configuration file. In the MirroringTransferServer provider, there is an attribute called “destination path” where you can set the temporary path. |
Changing numberOfPagesinPackage | By default the numberOfPagesInPackage is 500. Indicates the max number of pages in package. |
Changing numberOfFilesInpackage | By default the numberOfFilesInPackage is 100. Indicates the max number of files in package. |
Changing communication protocol | When the mirroring application is installed, basicHttpBinding will be used by default when communicating between the machines. To change this, change the bindings in the configuration files for both the source and the target application, see About WCF and Bindings on MSDN. |
Changing offlineLoggingEnabled and offlineLogPath | By default offline monitoring is disabled and can be enabled by setting the offlineLoggningEnabled to true. By default the path to offline monitoring log is "C:\Windows\Temp\episerver\cms6\mirroring\monitoring\" and it can be changed to another path by setting the offlineLogPath attribute. |
Source Connection String | By default the mirroring provider uses the connection string which is defined in the connectionStrings section. But you can change it by defining the sourceConnectionStringName attribute on the provider setting. |
Destination Connection String | By default the mirroring provider uses the connection string which is defined in the connectionStrings section. But you can change it by defining the destinationConnectionStringName attribute on the provider setting. This settings is useful when the mirroring provider take care both source and destination |
Using another mirroring provider | It is possible to use other mirroring providers than the built-in provider. Add the provider in the episerverMirroring section and set the defaultProvider to the provider you want to run. |
<episerverMirroring>
<mirroringTransfer defaultProvider="myMirroringProvider">
<providers>
<add
defaultEndpointName="mirroringTargetEndPoint"
destinationPath="c:\temp\mirroring\"
chunkSize="4194304"
name="MirroringTransferServer"
type="EPiServer.MirroringService.MirroringTransferProtocol.WCF.MirroringTransferClient,EPiServer.Enterprise"
username="XXXX"
password=""
domain="ep" />
<add
name="myMirroringProvider"
type="jobe.MirroringProvider, XXXX.Providers" />
</providers>
</mirroringTransfer>
<mirroringMonitoring offlineLoggningEnabled="true" offlinelogPath="Path to offline log"/>
</episerverMirroring>
When the Mirroring application is installed by the Deployment Center, it is installed as an application under the EPiServer CMS site chosen. To change the mirroring application to a separate site, you need to do the following:
<connectionStrings>
<add
name= "sourceDB"
connectionString="" />
<add
name= "destinationDB"
connectionString="" />
</connectionStrings>
<episerverMirroring>
<mirroringTransfer defaultProvider="MirroringTransferServer">
<providers>
<add
....
sourceConnectionStringName="sourceDB" />
destinationConnectionStringName="destinationDB" />
</providers>
</mirroringTransfer>
<mirroringMonitoring offlineLoggningEnabled="true" offlineLogPath="Path to offline log"/>
</episerverMirroring>
You need to synchronize the bin folders both under Site root folder and Mirroring Service bin folder. When assemblies in the site bin folder and mirroring service bin folder are not same, you will receive the following error when performing “Check System”:
It is important to have both bin folders synchronized with each other, since the Mirroring Service runs as a separate application and is having its own application pool. When you add any custom code/property/module under the source site, the affected assembly should be copied over to the Mirroring Service bin folder as well. If you have installed mirroring service on both source and destination sites, then Site and Mirroring Service must have the same assemblies under the bin folders.
Last updated: Feb 23, 2015