In-Memory OLTP 환경에서 체크포인트 작업과 디스크 부족 경고
- Version : SQL Server 2014, 2016
SQL Server 2014 버전부터 제공되는 인메모리 OLTP 기능을 사용하는 동안에도 여전히 충돌이나 재시작시 복구 시간을 줄일수 있는 방법이 필요하다. 디스크기반의 테이블 경우 체크포인트가 발생할때 디스크에 기록되지 않은 더티페이지가 디스크에 기록(플러시) 된다. 인메모리 OLTP의 경우에도 별도의 체크포인트 파일 세트가 있으며 체크포인트 파일은 MEMORY_OPTIMIZED_DATA 파일 그룹을 생성할 때 지정한 디렉토리에 생성된다.
인메모리 테이블에서 체크포인트시 디스크가 부족할 경우 데이터베이스는 온라인 상태로 유지되지만 아래와 같은 오류메시지가 나타난다.
2015-12-23 21:38:23.920 spid11s [ERROR] Failed to extend file 'f:\temp\imoltp_mod1\7ef8758a-228c-4bd3-9605-d7562d23fa76\a78f6449-bd73-4160-8a3f-413f4eba8fb300000ad-00013ea0-0002′ ('GetOverlappedResult'). Error code: 0x80070070. (d:\b\s1\sources\sql\ntdbms\hekaton\sqlhost\sqllang\fsstgl 2015-12-23 21:40:49.710 spid11s [ERROR] Database ID: [6]. Failure to allocate cache file. Error code: 0x80070070. (d:\b\s1\sources\sql\ntdbms\hekaton\engine\hadr\ckptagent.cpp : 890 – 'ckptAgentAllocateCfp') |
수동으로 체크포인트를 실행할 경우 아래와 같은 오류메시지가 나타난다.
Msg 41315, Level 16, State 0, Line 5
Checkpoint operation failed in database 'testdb'. |
디스크 부족 경고가 발생하면 다음과 같은 방법으로 해결할 수 있다.
- 디스크를 추가할 수 있으면 디스크를 추가한다.
- 디스크를 추가할 수 없으면 더 큰 공간이 있는 디스크에 MEMORY_OPTIMIZED_DATA 파일을 추가 생성한다.
ALTER DATABASE testdb ADD FILE (name='imoltp_mod1′, filename='f:\checkpoint\imoltp_mod1′) TO FILEGROUP imoltp_mod |
- 1단계 또는 2단계 작업이 완료되었으면 수동으로 체크포인트를 실행한다.
[참고자료]
강성욱 / jevida@naver.com
Microsoft SQL Server MVP
Blog : http://sqlmvp.kr
Facebook : http://facebook.com/sqlmvp