데이터베이스 개발자 Tip & 강좌

SQLER의 개발자들이 만들어가는 데이터베이스 사용자 Tip & 강좌 게시판입니다. SQL서버, Oracle, MySQL 등 여러 클라우드/오픈소스 기반 데이터베이스 개발 및 운영 관련 팁과 쿼리 노하우를 이곳에서 가장 먼저 접하실 수 있습니다. 많은 도움 되시길 바랍니다.

SQL Server 2016 DBCC CHECK 작업 성능 향상

  • Version : SQL Server 2016

대부분의 SQL Server (MULTI_OBJECT_SCANNER* base) 환경에서 DBCC CHECKS* (checkdb, checktable,…) 검사를 실행하는 동안 대기(wait)를 경험하게 된다. 내부적으로 DBCC CHECKS*를 실행하면 페이지 스캔 코디네이터 디자인(MultiObjectScanner)을 사용한다. SQL Server 2016 버전부터는 DBCC 작업시 이전보다 훨씬 더 확장 할 수 있도록 내부설계를 인모메리 최적화(Hekaton) 객체에 사용되는 것과 유사한 락(lock) 디자인을 적용하여 작업 성능을 향상 시켰다.

다음 차트는 동일한 1TB 데이터베이스의 테스트 결과를 나타낸다.

  • MultiObjectScanner : SQL Server 2016 이전 버전의 디자인
  • CheckScanner : SQL Server 2016 적용된 새로운 디자인

새롭게 적용된 디자인은 8코어 이상의 CPU에서 더 나은 결과를 제공한다. 하지만 8코어 이상에서는 성능이 크게 나아지지 않았다. 기존 디자인의 경우 코어가 많을수록 더 많은 실행 시간이 요구 되었다.

[데모 시나리오]

  1. SSMS에서 SQL Server 인스턴스에 연결 (2012 또는 2014)
  2. 새 쿼리창에서 데모 스크립트를 실행하고 실행 시간을 기록
  3. 동일한 하드웨어에서 SQL Server 2016 CTP 3.0 이상의 버전 인스턴스를 사용하여 데모 스크립트를 실행.

[시스템 사양]

Machine

32GB RAM, 4 Core Hyper-threaded enabled 2.8Ghz, SSD Storage

SQL Server

Out of the box, default installation

[데모 결과 (7번 실행)]

SQL Server 2014

12880ms

SQL Server 2016

1676ms

[데모 스크립트]

use tempdb

go

set nocount on

go

if(0 <> (select count(*) from tempdb.sys.objects where name = 'tblDBCC') )

begin

    drop table tblDBCC

end

go

create table tblDBCC (

iID int NOT NULL IDENTITY(1,1) PRIMARY KEY CLUSTERED,

strData nvarchar(2000) NOT NULL

)

go

--Insert data to expand to a table that allows DOP activities

print 'Populating Data'

go

begin tran

go

insert into tblDBCC (strData) values ( replicate(N'X', 2000) )

while(SCOPE_IDENTITY() < 100000)

begin

    insert into tblDBCC (strData) values ( replicate(N'X', 2000) )

end

go

commit tran

go

-- CheckDB

declare @dtStart datetime

set @dtStart = GETUTCDATE();

dbcc checkdb(tempdb)

select datediff(ms, @dtStart, GetUTCDate()) as [Elapsed DBCC checkdb (ms)]

go

[참고자료]

https://blogs.msdn.microsoft.com/psssql/2016/02/25/sql-2016-it-just-runs-faster-dbcc-scales-7x-better/





강성욱 / jevida@naver.com
Microsoft SQL Server MVP
Blog : http://sqlmvp.kr
Facebook : http://facebook.com/sqlmvp

No. Subject Author Date Views
2070 SQL Server 2016 Multiple Log Writer Workers jevida(강성욱) 2017.01.11 3798
2069 SQL Server 2016 Larger Data File Writes jevida(강성욱) 2017.01.11 3184
2068 SQL Server 2016 향상된 업데이트 스케줄링 알고리즘 jevida(강성욱) 2017.01.11 3649
2067 SQL Server 2016 Automatic Soft NUMA jevida(강성욱) 2017.01.11 3098
2066 SQL Server 2016 Tempdb 환경 설정 jevida(강성욱) 2017.01.11 4383
2065 SQL Server 2016 향상된 즉시 파일 초기화 jevida(강성욱) 2017.01.11 2755
2064 SQL Server 2016 LDF 생성 또는 증가 시 변경된 스탬프 패턴 jevida(강성욱) 2017.01.11 2633
2063 SQL Server 2016 Tempdb 성능 향상 jevida(강성욱) 2017.01.11 4702
» SQL Server 2016 DBCC CHECK 작업 성능 향상 jevida(강성욱) 2017.01.11 2374
2061 Microsoft Azure - SQL Server가 포함된 가상 컴퓨터 생성하기 jevida(강성욱) 2017.01.11 1840
2060 데이터베이스에서 사용자 삭제 오류 jevida(강성욱) 2017.01.11 1303
2059 Sys.dm_exec_query_plan 에서 query_plan 컬럼의 NULL 값 반환 jevida(강성욱) 2017.01.11 1873
2058 SSMS에서 유효하지 않은 소유자로 데이터베이스 정보가 보이지 않는 증상 jevida(강성욱) 2017.01.11 1834
2057 SQLCMD 유틸리티 사용하기 jevida(강성욱) 2017.01.11 7837
2056 In-Memory 최적화 테이블을 사용하여 임시 테이블 및 테이블 변수 성능 향상 jevida(강성욱) 2017.01.11 4484
2055 SQL Server Job Agent는 몇 개까지 실행이 가능할까? jevida(강성욱) 2017.01.11 1757
2054 확장이벤트 사용시 주의사항 jevida(강성욱) 2017.01.11 1631
2053 Unix(Linux) timestamp(bigint) 형식을 datetime 으로 변경하기 jevida(강성욱) 2017.01.11 2953
2052 Query Rule Off를 사용한 SQL Server 옵티마이저 비활성화 jevida(강성욱) 2017.01.11 1571
2051 시스템 관리자 권한이 없는 특정 프로그램에서 Trace Flag 사용하기 jevida(강성욱) 2017.01.11 2305





XE Login