You know how SQL server checks whether the page is good or corrupted?
There are two ways by which SQL Server finds the corrupted page:Torn Page Detection and Checksum.
Checksum is a new type of page verification introduced in SQL Server 2005 which offers better corruption checking than torn page detection.This is why when we create a new database in SQL Server 2005 or 2008 the checksum option is turned on by default.
What Checksum do?
For a database with checksum ON SQL Server computes the checksum of the page both when a page is written and when a page is read. The SQL Server computes the checksum based on the bit pattern on the page, stores it in the page header and then issues an I/O to write the page. When the SQL Server reads the page, it re-computes the checksum using the same logic and then compares it with the value available in the page header. If the checksum value matches then it is assumes the page did not get corrupted during the write-read cycle.Keep in mind that checksum is not 100% accurate and there are cases when corruption remains undetected even if you have checksum enabled.
How Torn Page Detection works?
Torn page detection on the other hand does a different type of page verification in which it writes a bit for every 512 byte of a page. This will help you in finding whether the page has been succesfully written or not but it cant tell you whether the data you have written is correct or not. We can use the same checksum for verifying backup.This will give added protection for backup.
How to enable page verification?
--CHECKSUM
ALTER DATABASE RKN set PAGE_VERIFY CHECKSUM
--TORN PAGE DETECTION
ALTER DATABASE RKN SET PAGE_VERIFY TORN_PAGE_DETECTION
You can also change the page verify option using GUI
DATABASE PROPERTIES-->OPTIONS-->PAGE VERIFY Here you can select the type of page verification you want.
Sunday, July 18, 2010
Monday, July 12, 2010
LOCKS in DB2
I found it not as easy as SQL Server to manage DB2 servers when it comes to administration.
Here I am briefing on how to find the locks on DB2 and how to configure the configuration manager so that we can capture the locks.
First we need to update the database manager for configuration to change the parameter DFT_MON_LOCK to ON.
UPDATE DATABASE MANAGER CONFIGURATION USING DFT_MON_LOCK ON
Then we need to update the monitor switches so that we can view the locks
UPDATE MONITOR SWITCHES USING LOCK ON
The above command will help you in updating the monitor switch.
Now we have all set so that we can check the locks on particular database.
GET SNAPSHOT FOR LOCKS ON DB_NAME will give us the list of all locks currently on that particular database.
We can kill the process by using the command
FORCE APPLICATION(APPLICATION_HANDLE)
APPLICATION_HANDLE is a unique number which we will get when we check the lock using GET SNAPSHOT FOR LOCKS ON DB_NAME along with the object name causing lock.
FORCE APPLICATION ALL will kill all the process on the particular database where we executing the command.
Here comes a handy script for viewing locks.This is very helpful as it gives a detailed information on application connecting,IP address,Victim etc.
--SCRIPT TO VIEW LOCKS
Select substr(ai.appl_name,1,10) as Application,
substr(ai.primary_auth_id,1,10) as AuthID,
int(ap.locks_held) as "# Locks",
int(ap.lock_escals) as "Escalations",
int(ap.lock_timeouts) as "Lock Timeouts",
int(ap.deadlocks) as "Deadlocks",
int(ap.int_deadlock_rollbacks) as "Dlock Victim",
substr(inbound_comm_address,1,15) as "IP Address"
from sysibmadm.snapappl ap, sysibmadm.snapappl_info ai
where ap.agent_id = ai.agent_id
;
Here I am briefing on how to find the locks on DB2 and how to configure the configuration manager so that we can capture the locks.
First we need to update the database manager for configuration to change the parameter DFT_MON_LOCK to ON.
UPDATE DATABASE MANAGER CONFIGURATION USING DFT_MON_LOCK ON
Then we need to update the monitor switches so that we can view the locks
UPDATE MONITOR SWITCHES USING LOCK ON
The above command will help you in updating the monitor switch.
Now we have all set so that we can check the locks on particular database.
GET SNAPSHOT FOR LOCKS ON DB_NAME will give us the list of all locks currently on that particular database.
We can kill the process by using the command
FORCE APPLICATION(APPLICATION_HANDLE)
APPLICATION_HANDLE is a unique number which we will get when we check the lock using GET SNAPSHOT FOR LOCKS ON DB_NAME along with the object name causing lock.
FORCE APPLICATION ALL will kill all the process on the particular database where we executing the command.
Here comes a handy script for viewing locks.This is very helpful as it gives a detailed information on application connecting,IP address,Victim etc.
--SCRIPT TO VIEW LOCKS
Select substr(ai.appl_name,1,10) as Application,
substr(ai.primary_auth_id,1,10) as AuthID,
int(ap.locks_held) as "# Locks",
int(ap.lock_escals) as "Escalations",
int(ap.lock_timeouts) as "Lock Timeouts",
int(ap.deadlocks) as "Deadlocks",
int(ap.int_deadlock_rollbacks) as "Dlock Victim",
substr(inbound_comm_address,1,15) as "IP Address"
from sysibmadm.snapappl ap, sysibmadm.snapappl_info ai
where ap.agent_id = ai.agent_id
;
Subscribe to:
Posts (Atom)