optimizing sql server 2012 for sharepoint 2013 sharepoint saturday/friday, honolulu march 27, 2015

33
Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Upload: charity-mitchell

Post on 23-Dec-2015

222 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Optimizing SQL Server 2012 for SharePoint 2013

SharePoint Saturday/Friday, HonoluluMarch 27, 2015

Page 2: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

With Mahalo to our sponsors:

Prize sponsors include:

CBT Nuggets

Mail2Share

VisualSP

Mahalo!

Page 3: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

About the Speaker

• Brian Alderman (MCT / Author / Speaker / Consultant)• CBT Nuggets – www.cbtnuggets.com • [email protected]• @brianalderman @cbtnuggets• www.microtechpoint.com – Brian’s Blog• Co-Author SharePoint 2010 Administrator’s Companion• Co-Author SharePoint 2013 Administration Inside Out• Enjoy Travel and Golf

Page 4: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015
Page 5: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Over 300 Courses and 4500 Hours of ContentMicrosoft, Cisco, Juniper, CompTIA, VMWare, PMP, and MoreLaptop, Tablet, or Mobile DeviceUnder $85 a Month SharePoint Super End User Trifecta: SharePoint 2013 Site Collection Administration SharePoint 2013 Site Owners SharePoint 2013 Collaboration ExpertManaging Office 365 Identities and Requirements (70-346 Exam)Free Seven Day Trial

Page 6: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015
Page 7: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Mulletville, Vermont

Page 8: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Garden of the Gods with Pikes Peak

Page 9: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Arizona Golf

Page 10: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

19th Hole

Page 11: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015
Page 12: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

SQL Server IntroductionSharePoint and SQL Server IntegrationDemo: SQL Server Configurations to Optimize SharePoint

SQL Server Instance Configurations Database Configurations

Avoiding Ginormous Transaction LogsSQL Server Best Practices for Optimizing SharePoint

Session Agenda

Page 13: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

SQL Server Introduction

Page 14: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Multiple Instances of SQL Server on One ServerOne Default Instance with Multiple Name InstancesEach Instance Managed Individually

Share SQL Server Management ToolsEach Instance Shares Windows Server ResourcesTwo Types of Databases: System and UserMinimum of Two Files Created Per Database

MDF (Master Data File) LDF (Transaction Log File) NDF (Optional for Extending Database)

SQL Server Introduction

Page 15: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

SQL Server Transaction Log Process

Modification is sent byapplication to SQL Server1

Data pages are located in, or read into the buffer cache and then modified

2

Buffer Cache

Modification is recorded in transaction log on disk3

Later, CHECKPOINT writesdirty pages to database4

LDF

MDF

Page 16: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Working with Recovery ModelsRecovery Model Description

Simple Does NOT permit transaction log (t-log) backups. Automatically truncates log to reduce space requirements

Full Requires LOG BACKUPS to manage t-log space requirements. Avoids data loss if damaged or missing database file occurs. Permits point-in-time recovery.

Bulk Logged Requires log backups to manage t-log space requirements. Improves performance during bulk copy operations. Reduces t-log space usage by using minimal logging of operations.

Page 17: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Simple Recovery Model Sample DataData pages are located in, or read into, the buffer cache and then modified2Modification is sent byapplication to SQL Server1Modification is recorded in transaction log on disk3Later, CHECKPOINT writesdirty pages to databaseand FLUSHES transactions from T-log. 4BufferCache

Page 18: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Full Recovery Model Sample DataData pages are located in, or read into, the buffer cache and then modified2Modification is sent byapplication to SQL Server1Modification is recorded in transaction log on disk3Later, CHECKPOINT writesdirty pages to databasebut RETAINS transactions in T-log. 4BufferCache

Page 19: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Master Configuration Database of SQL Server Instance

MsdbStorage of SQL Server Automation Configuration Information

Resource (Hidden)Read-Only Database Containing All SQL Server System Objects

TempdbTemporary Work Storage Area

ModelTemplate Used to Create All New Databases

SQL Server Instance Databases

Page 20: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

SharePoint and SQL ServerIntegration

Page 21: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

All SQL Server Versions and SharePoint VersionsLarge Majority of SharePoint Data Stored in SQL ServerFarm Configuration Information Stored in SharePoint Configuration Database in SQL ServerCentral Administration Content Stored in Own Content Database in SQL Server (Blog on how to rename)Every Web Application Minimum of One Content Database (Blog on how to rename)Most Service Applications Have at Least One Database

SharePoint and SQL Server Integration

Page 22: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

SharePoint Farm Creates Several Databases (20 DB’s if Spousal Installation and Run Configuration Wizard) Content Database Contains Several Site CollectionsSite Collection Resides in Only One Content DatabaseUse Full Recovery Model on Production DatabasesControl Size of Database (Recommended 200GB)

Site Collection Quota Templates Maximum Number of Site Collections per Database

SharePoint Content Databases

Page 23: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Controlling Size of Content Databases

Web Application200GB 200GB 200GB 200GB

Site Collections Site Collections Site Collections Site Collections

ProjectSites

DepartmentSites

HRSites

MarketingSites

Require 800 Site Collections with 500 MB Quota

750mb X 250 = 187,500mb / 1024 = 183gb

250 250 250 250

Page 24: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Default File Locations (Move off C:\ Drive)Minimum and Maximum Memory SettingsMax Degree of Parallelism (MAXDOP) Set to 1 Don’t Enable Auto_Create or Auto_Update Statistics on SP DB’sHave DBA Create Alias for SharePoint SQL Instance Not Used by FAST Search SKU (SharePoint 2010, try DNS Alias)SharePoint Collation – Latin1_General_CI_AS_KS_WS

During Installation of SQL Server Hosting SharePoint ContentDuring Creation of Content Database in SQL Server

SQL Server Instance Configuration

Page 25: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Model Database File SettingsIncrease Initial Size of Data and Log FilesIncrease Autogrowth Settings (Use MB not %)

Tempdb Database File Settings Increase Initial Size of Data and Log FilesIncrease Autogrowth Settings (Use MB not %) Use Simple Recovery Model Place Files on Different Drive from Content Databases

SQL Server Database Configuration

Page 26: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Demo

SQL Server Configurations

Page 27: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Avoiding Ginormous Transaction Logs

Page 28: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Avoiding Ginormous Transaction Logs

mdf ldf

Sunday

Full Backup

mdf ldf

Tuesday

Differential

mdf ldf

Differential

Monday

mdf ldf

Differential

Wednesday

You Lose mdf file of database on Thursday at 4:00pm

(1) BACKUP LOG DB_Name TO D:\SQLBackups\TempBackup.Bak WITH NORECOVERY

(2) Restore Full Backup from Sunday (3) Restore Differential Backup from Wednesday

(4) RESTORE LOG FROM D:\SQLBackups\TempBackup.Bak

BACKUP LOG DB_Name TO D:\SQLBackups\Weekly_T_Log.Bak WITH INIT

Page 29: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Best Practices for Optimizing SharePoint

Page 30: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Dedicated SQL Server Instance / ServerNo Spousal Installations of SQL Server or SharePointDatabase Size Should Not Exceed 200GBMax Degree of Parallelism (MAXDOP) Set to 1Create SQL Alias for SQL Server SharePoint InstanceModify Model System Database Settings Avoid Auto-Shrinking DatabasesUse Database Autogrowth Sparingly

Reduces FragmentationImproves Data Entry Performance

Best Practices for SharePoint’s SQL Server

Page 31: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Spread Data Files and Transaction Log Files Across Multiple Drives or Locate them on RAID 5/10Create Multiple Tempdb Files on Multiple Drives or RAID 10 for

Drive Hosting Tempdb FilesGenerate Database Maintenance PlansDefragment Drives Containing Content Database FilesDon’t Rebuild or Manage Indexes of SharePoint DB’sPerform Regular Backups of Database and T-LogsContinuously Monitor SQL Server Storage and PerformancePerform DBCC CHECKDB Operations RegularlyJust Say NO to Simple Recovery Model

Best Practices for SharePoint’s SQL Server

Page 32: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Thank You for Attending

Page 33: Optimizing SQL Server 2012 for SharePoint 2013 SharePoint Saturday/Friday, Honolulu March 27, 2015

Mahalo for Attending