Run a farm that uses read-only databases (SharePoint Foundation 2010)
Applies to: SharePoint Foundation 2010
This article describes how to run a Microsoft SharePoint Foundation 2010 farm in which some or all databases are set to be read-only (a read-only farm).
A farm is considered to be read-only if any of the following are true:
All content databases are set to read-only.
Service application databases are set to read-only.
The functionality and user experience in a read-only farm depends on which databases are set to read-only.
A farm that uses read-only content and service application databases is likely to be part of a disaster recovery environment or a highly available maintenance, update, or upgrade environment.
Procedures in this task:
Prepare users for the read-only experience
Set content databases to be read-only
Set service application databases to be read-only
If you plan to provide users with access to a read-only site or farm, you should set expectations for what they will be able to do on the site and how the user interface (UI) will differ.
The user experience of a site that uses a content database that is set to read-only is characterized by the following:
Common tasks that do not require writing to the content database are fully available.
Most of the common tasks that require writing to the content database are not available, either because they have been disabled in the UI, or because the user is no longer allowed to apply changes.
Some common tasks that require writing to the content database appear to be available, but return errors.
For detailed information about the user experience on a read-only site, see User experience on read-only sites (SharePoint Foundation 2010).
The user experience of a farm that uses service application databases that are set to read-only is characterized by the following:
Common tasks that do not require writing to the service databases are fully available.
All common tasks that require writing to the service databases appear to be available, but return errors.
Before you set content databases to be read-only, you may need to determine which content database is associated with a particular site collection.
To determine which content database is associated with a site collection
Verify that you meet the following minimum requirements: See Add-SPShellAdmin.
On the Start menu, click All Programs.
Click Microsoft SharePoint 2010 Products.
Click SharePoint 2010 Management Shell.
At the Windows PowerShell command prompt (PS C:\>), type the following command, and then press ENTER:
Get-SPContentDatabase -Site <Site URL>
-Site specifies the site collection for which you want to know the associated content database.
The command returns the content database associated with the site.
For more information, see Get-SPContentDatabase.
Note
We recommend that you use Windows PowerShell when performing command-line administrative tasks. The Stsadm command-line tool has been deprecated, but is included to support compatibility with previous product versions.
You can use the following procedure to set read/write content databases to be read-only by using SQL Server Management Studio. You can also use the Transact-SQL ALTER DATABASE statement to set content databases to be read-only. For more information, see ALTER DATABASE (Transact-SQL) (https://go.microsoft.com/fwlink/p/?LinkId=148619).
Important
Do not perform this procedure on databases in a failover environment that have been log-shipped or mirrored.
To set content databases to be read-only
Verify that you have the following administrative credentials: You must be a member of the db_owner fixed database role in each database.
Open SQL Server Management Studio.
Right-click the content database that you want to change to read-only, and then click Properties.
Select the Options page, and, in the Other options list, scroll to the State section.
In the Database Read-Only row, click the arrow next to False, select True, and then click OK.
Repeat for all other content databases.
Note
When a database is set to read-only, all connections except the one that is setting the read-only flag are stopped. After the read-only flag is set, other connections are enabled.
The site collection that is associated with a read-only content database is automatically set to be read-only if the locking status of the site collection was previously None, No Additions, or Read-Only. If the locking status of the site collection was previously No Access, it remains No Access when the database locking status is changed.
It is possible to set any service application database to be read-only. However, some service applications do not function when their databases are set to read-only.
To set service application databases to be read-only
Verify that you have the following administrative credentials: You must be a member of the db_owner fixed database role in each database.
Open SQL Server Management Studio.
Right-click the database that you want to change to read-only, and then click Properties.
Select the Options page, and, in the Other options list, scroll to the State section.
In the Database Read-Only row, click the arrow next to False, select True, and then click OK.
Repeat for other service application databases as appropriate.
Note
When a database is set to read-only, all connections except the one that is setting the read-only flag are stopped. After the read-only flag is set, other connections are enabled.