Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle...

67
Performance tuning and SQL Nexus Michelle Gutzait [email protected] [email protected] Blog: http://michelle-gutzait.spaces.live.com/default.aspx

Transcript of Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle...

Page 2: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Whoami?

SQL Server Consultant@ www.pythian.com

24/7 Remote DBA services

Page 3: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 4: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

The big boss

The developers

The junior developers

The analysts

He who

thinks he’s

the big boss

The users

“My” DB server

Page 5: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 6: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

What I would like EVERYONE to THINK I do !

Page 7: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

A DBA

Page 8: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Fast +

Page 9: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

So that I can REALLY BE…

Page 10: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 11: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Unknown

Defined

Page 12: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

My SP is

timing out !!

The report

is slow

This

update

timeouts

The job is

taking too

long

This query

is the

deadlock

victim

Page 13: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 14: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 15: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Server is too slow Something is broken

Application crashes Weird behavior

Timeouts

Page 16: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 17: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Top down Bottom up

Page 18: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

TOP DOWN is the best

approach.

Page 19: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Also for:

Capacity Planning

Periodical performance reviews

And (probably) more…

Page 20: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 21: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Windows Performance Monitor

SQL Server Profiler &

SQL Traces

ReadTrace

SQL Server Management Studio

Windows Management Instrumentation

(WMI)

Page 22: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Database Engine Tuning Advisor

DMVs and statistics

SQL Server 2008 Activity Monitor

SQL Server 2008 and R2 Ent tools…

Page 23: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

PSSDiag

SQLDiag and PerfStats

Performance Analysis of Logs

(PAL)

Page 24: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

3-rd party tool

Page 25: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

I like it simple!!

Page 26: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Michelle’s… Performance Counters

Page 27: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

There are too MANY things to check for!

Page 28: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 29: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Hardware

Operating System

SQL Server

(Network?)

Database applications

Page 30: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

CPU

Memory

IO

SQL Server

(Network?)

Page 31: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Windows Performance Monitor

DMVs

SQL Server Profiler &

SQL Traces

Page 32: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Performance analysis

with

Windows Performance

Monitor…

Page 33: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

OS/HARDWARE SQL SERVER

Page 34: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 35: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

CPU analysis

Page 36: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Memory analysis

Page 37: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

SQL Server Memory

Page 38: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

IO and disk analysis

Page 39: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

SQL Server behavior

Page 40: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Performance analysis

with

DMVs

Page 41: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 42: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Troubleshooting Performance Problems in SQL Server 2005

http://technet.microsoft.com/library/Cc966540#EFAA

Page 43: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

SCRIPT REPOSITORIES

Page 44: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

CPU analysis

Number of runnable tasks in each

scheduler

Which currently

cached batches or

procedures are using

the most CPU

Page 45: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

SQL Server Memory analysis

Analysis of internal

memory pressure in

SQL Server

amount of memory consumed by

different SQL Server components

Page 46: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Latch waits - physical I/O waits

when a page is not available in

the buffer pool.

Currently pending I/O requests

IO and disk analysis

Page 47: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

And much more…

WAIT STATISTICS

INDEX ANALYSIS

CACHE PLAN

TEMPDB USAGE

HEAVY T-SQL

BLOCKS/LOCKS

DEADLOCKS

ETC… ETC… ETC…

Page 48: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Michelle’s…

Index and T-SQL

Analysis with

DMVs

Page 49: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Performance analysis

with

SQL Profiler

Page 50: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Again…

T-SQL ANALYSIS

BLOCKS/LOCKS

DEADLOCKS

LOGINS/LOGOUTS

COMPILATIONS/RECOMP

ERRORS AND WARNINGS

CACHE MISSES

ETC… ETC… ETC…

Page 51: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

How do YOU FEEL about the

EXCESSIVE INFO?

Page 52: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Fast +

Page 53: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 54: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

PSSDIAG for SQL Server 7

and 2000

Installed with SQL Server

2005 and higher

Page 55: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

COMPONENTS

SQL Traces

Performance Monitor

Others: Event Logs, Error

Logs, mini-dumps, msinfo32

Page 56: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

COMPONENTS

Add your own

Example: pull data from DMVs

Page 57: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Features

Command line

Service

Scheduled

XML config file

One or all instances

Page 58: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 59: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Wait stats (DMVs)

SQLDiag

SQL Traces

Custom XML files

Blocks/locks (DMVs)

Integrated with SQLNexus

Page 60: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 61: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

HTML REPORT

Page 62: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 63: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

Cumulative query

performance data

Integrated with SQLNexus

Part of the RML

Utilities package

Multiple files

Page 64: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor

SSRS reporting

+ Extended reports

SQLDiag / PerStats

ReadTrace

Page 65: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor
Page 66: Performance tuning and SQL - WordPress.com€¦ · Performance tuning and SQL Nexus Michelle Gutzait gutzait@pythian.com Michelle.gutzait@gmail.com ... Windows Performance Monitor