This document lists the best practices that Workload Manager supports for evaluating SQL Server workloads running on Google Cloud. To learn about Workload Manager, see Product overview.
Severity levels
When you run an evaluation, Workload Manager evaluates resources by comparing their current state with best practices. If a resource doesn't comply with a selected best practice, Workload Manager assigns it a severity level that indicates how far the resource is out of compliance. The Google Cloud console marks each non-compliant resource with an icon. The following table explains these icons, their corresponding severity levels, how the current resource setting might impact your workload, and recommendations for modifying the resource to adhere to best practices.| Icon | Severity level | Impacts | Recommendation | 
|---|---|---|---|
| Critical | System Reliability, Unplanned Outages, Unsupported Configuration | Resolve as soon as possible to prevent an impact on system availability and data integrity due to a high risk of an unplanned outage. | |
| High | Degraded Performance, System Stability | Resolve during the next planned maintenance window. | |
| Medium | Suboptimal Performance, Supportability | Resolve at your earliest convenience. | |
| Low | Informational, Non-essential Behavior | Although there's no resolution needed, reviewing this best practice can provide useful insights. | 
Best practices for SQL Server workloads
The following table shows the Workload Manager best practices for evaluating SQL Server workloads that run on Google Cloud.
Note that to enable Workload Manager for evaluating your SQL Server workloads, you must set up Google Cloud's Agent for SQL Server on the host VMs.
| Category | Best practice name and description | Severity | 
|---|---|---|
| Stability | SQL: Perform backup regularly When taking regular database backups, be careful not to consume too many persistent disk IOPS. Use the local SSD to stage your backups and then push them to a Cloud Storage bucket.For more information, see Backing up in Best practices for SQL Server VMs. |  | 
| Performance | SQL: Enable the buffer pool extension The buffer pool extension feature lets you push clean pages to a local SSD, instead of dropping them. This works along the same lines as virtual memory, which is to say, by swapping, and gives you access to the clean pages on the local SSD, which is faster than going to the regular disk to fetch the data.For more information, see Enabling the buffer pool extension in Best practices for SQL Server VMs. |  | 
| Performance | SQL: Format secondary disks Formatting a disk with a 64 KB allocation unit lets SQL Server read and write extents more efficiently, which increases the I/O performance of the disk. |  | 
| Failover Clustering | SQL: Enable failover clustering 
            To enable failover clustering in the Compute Engine agent, you need
            to add the flag  |  | 
| Performance | SQL: Avoid index fragmentation If one or more indexes are 95%+ fragmented, we recommend scheduling defrag jobs. |  | 
| Performance | SQL: Move data files and log files to a new disk By default, the preconfigured image for SQL Server comes with everything installed on the boot persistent disk, which mounts as the `C:` drive. Consider attaching a secondary SSD persistent disk and moving the log files and data files to the new disk.For more information, see Place data and log files on separate drives in SQL Server documentation. |  | 
| Stability | SQL: Match max server memory setting with available physical memory on the instance 
            We recommend that the  |  | 
| Performance | SQL: Set the power profile to High-Performance
            To configure SQL Server for optimal performance on Google Cloud, we recommend that you set the power profile to  |  | 
| Performance | SQL: Match max degree of parallelism to the number of CPUs on the server 
            Google Cloud recommends that the default setting for
             |  | 
| Performance | SQL: Use compressed tables Compressing tables could make your system perform faster.For more information, see Using compressed tables in Best Practices for SQL Server VMs. |  | 
| Performance | SQL: Use Local SSDs for tempDB Create new SQL Server instances with one or more local SSDs to store the tempDB and Windows paging files. |  | 
| Performance | SQL: Set log file to fixed amount and schedule regular backups Consider disabling autogrowth and setting your log file to a fixed size. |  | 
| Performance | SQL: Optimize Virtual Log Files Monitor Virtual Log File growth and take action to prevent log file fragmentation.For more information, see Optimizing virtual log files in Best Practices for SQL Server VMs. |  | 
| Cost Optimization | SQL: Disable simultaneous multithreading (SMT) Disabling SMT reduces the number of vCPUs for each core by half, which might reduce your licensing costs. For more information, consult your licensing agreement. An industry best practice for an optimal TCO for most SQL Server workloads is to set the number of threads per core to one, and then to right-size the VM shape according to the workload requirements. Controlling the number of cores is further possible using custom visible cores. Consult your technical account manager for further details.For more information, see how to set the number of threads per core. |  | 
| Stability | SQL: Google Cloud Backup and Disaster Recovery agent not detected Consider Google's backup and disaster recovery solutions for optimal protection.For more information, see Backup and DR Service. |  |