데이터베이스 엔진 서비스 시작 옵션

시작 옵션은 시작하는 동안 필요한 특정 파일 위치를 지정하고 일부 서버 차원의 조건을 지정합니다. 일반적으로 데이터베이스 엔진 에 문제가 발생하거나 예외적인 문제가 발생하여 SQL Server 고객 지원 서비스에서 시작 옵션을 사용하도록 지시하는 경우가 아니면 시작 옵션을 지정할 필요가 없습니다.

경고

시작 옵션을 잘못 사용하면 서버 성능에 영향을 주고 SQL Server 가 시작되지 않을 수 있습니다.

시작 옵션 정보

SQL Server를 설치할 때 Microsoft Windows 레지스트리에 기본 시작 옵션 집합이 기록됩니다. 이 시작 옵션을 사용하여 대체 master 데이터베이스 파일, master 데이터베이스 로그 파일 또는 오류 로그 파일 등을 지정할 수 있습니다. 데이터베이스 엔진 에서 필요한 파일을 찾지 못하면 SQL Server 가 시작되지 않습니다.

시작 옵션은 SQL Server 구성 관리자를 사용하여 설정할 수 있습니다. 자세한 내용은 서버 시작 옵션 구성(SQL Server 구성 관리자)을 참조하세요.

시작 옵션 목록

기본 시작 옵션 Description
-dmaster_file_path master 데이터베이스 파일의 정규화된 경로입니다. 일반적으로 C:\Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\Data\master.mdf입니다. 이 옵션이 제공되지 않으면 기존의 레지스트리 매개 변수를 사용합니다.
-eerror_log_path 오류 로그 파일의 정규화된 경로입니다. 일반적으로 C:\Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\LOG\ERRORLOG입니다. 이 옵션이 제공되지 않으면 기존의 레지스트리 매개 변수를 사용합니다.
-lmaster_log_path master 데이터베이스 로그 파일의 정규화된 경로입니다. 일반적으로 C:\Program Files\Microsoft SQL Server\MSSQL.n\MSSQL\Data\mastlog.ldf입니다. 이 옵션을 지정하지 않으면 기존의 레지스트리 매개 변수가 사용됩니다.
다른 시작 옵션 Description
-c 명령 프롬프트에서 SQL Server 를 시작할 때 시작 시간을 단축시킵니다. 일반적으로 SQL Server 데이터베이스 엔진 은 서비스 제어 관리자를 호출하여 서비스로 시작됩니다. SQL Server 데이터베이스 엔진 은 명령 프롬프트에서 시작하는 경우 서비스로 시작되지 않으므로 -c 를 사용하여 이 단계를 건너뛸 수 있습니다.
-f SQL Server 인스턴스를 최소 구성으로 시작합니다. 예를 들어 오버 커밋 메모리 같은 구성 값의 설정 때문에 서버를 시작할 수 없을 경우에 유용합니다. SQL Server 를 최소 구성 모드로 시작하면 SQL Server 가 단일 사용자 모드로 실행됩니다. 자세한 내용은 뒷부분에 나오는 -m 에 대한 설명을 참조하세요.
-gmemory_to_reserve SQL Server 프로세스 내에서 SQL Server 메모리 풀 외부에서 메모리 할당에 사용할 수 있게 SQL Server 메모리의 정수(MB)를 지정합니다. 메모리 풀 외부의 메모리는 확장 프로시저 .dll 파일, 분산 쿼리에서 참조하는 OLE DB 공급자 및 Transact-SQL 문에서 참조되는 자동화 개체와 같은 항목을 로드하는 데 SQL Server 사용하는 영역입니다. 기본값은 256MB입니다.

이 옵션을 사용하면 메모리 할당을 튜닝하는 데 도움이 될 수 있으나 실제 메모리가 운영 체제에서 애플리케이션에 사용할 수 있도록 구성된 가상 메모리 한계보다 큰 경우에만 사용할 수 있습니다. 이 옵션은 SQL Server 메모리 사용 요구 사항이 비정형이고 SQL Server 프로세스의 가상 주소 공간이 완전히 사용 중인 대용량 메모리 구성에 적합할 수 있습니다. 이 옵션을 잘못 사용하면 SQL Server instance 시작되지 않거나 런타임 오류가 발생할 수 있는 조건이 발생할 수 있습니다.

SQL Server 오류 로그에 다음 경고가 표시되지 않는 한 -g 매개 변수의 기본값을 사용합니다.

-"실패한 가상 할당 바이트: FAIL_VIRTUAL_RESERVE <크기>"

-"실패한 가상 할당 바이트: FAIL_VIRTUAL_COMMIT <크기>"

이러한 메시지는 SQL Server 확장 저장 프로시저 .dll 파일 또는 자동화 개체와 같은 항목의 공간을 찾기 위해 SQL Server 메모리 풀의 일부를 해제하려고 함을 나타낼 수 있습니다. 이 경우 -g 스위치로 예약되는 메모리 양을 늘려 보세요.

기본값보다 낮은 값을 사용하면 SQL Server Memory Manager 및 스레드 스택에서 관리하는 메모리 풀의 사용 가능한 메모리 양을 증가시켜 확장 저장 프로시저, 분산 쿼리, 자동화 개체 등을 사용하지 않는 시스템에서 메모리 집중형 작업에 대한 성능상의 이점을 제공할 수 있습니다.
-m SQL Server 인스턴스를 단일 사용자 모드로 시작합니다. SQL Server 인스턴스를 단일 사용자 모드로 시작하면 한 사용자만 연결할 수 있으며 CHECKPOINT 프로세스가 시작되지 않습니다. CHECKPOINT는 디스크 캐시에 있는 완료된 트랜잭션이 정기적으로 데이터베이스 디바이스에 기록되도록 합니다. 일반적으로 이 옵션은 복구해야 할 시스템 데이터베이스에 문제가 발생했을 때 사용합니다. sp_configure allow updates 옵션을 설정합니다. 기본적으로 allow updates는 사용할 수 없습니다. 단일 사용자 모드로 SQL Server 를 시작하면 컴퓨터에서 로컬 Administrators 그룹의 모든 멤버가 sysadmin 고정 서버 역할의 멤버로 SQL Server 인스턴스에 연결할 수 있습니다. 자세한 내용은 시스템 관리자가 잠겨 있는 경우 SQL Server에 연결을 참조하세요. 단일 사용자 모드에 대한 자세한 내용은 단일 사용자 모드로 SQL Server 시작을 참조하세요.
-m"클라이언트 애플리케이션 이름" SQLCMD 또는 SQL Server Management Studio -m 옵션을 사용하는 경우 지정된 클라이언트 애플리케이션에 대한 연결을 제한합니다. 예를 들어 -m"SQLCMD" 는 연결 수를 단일 연결로 제한하며 해당 연결은 자신을 SQLCMD 클라이언트 프로그램으로 식별해야 합니다. 단일 사용자 모드에서 SQL Server 를 시작하며 알 수 없는 클라이언트 애플리케이션에서 사용 가능한 유일한 연결을 사용할 경우 이 옵션을 사용합니다. Management Studio에서 쿼리 편집기를 통해 연결하려면 -m"Microsoft SQL Server Management Studio - 쿼리" 를 사용합니다.

클라이언트 애플리케이션 이름은 대/소문자를 구분합니다.

** 보안 참고 ** 이 옵션을 보안 기능으로 사용하지 마세요. 클라이언트 애플리케이션에서 클라이언트 애플리케이션 이름을 제공하므로 연결 문자열의 일부로 잘못된 이름을 제공할 수 있습니다.
-n SQL Server 이벤트를 기록하는 데 Windows 애플리케이션 로그를 사용하지 않습니다. SQL Server -n 으로인스턴스를 시작하는 경우 -e 시작 옵션도 사용하는 것이 좋습니다. 그렇지 않으면 SQL Server 이벤트가 로깅되지 않습니다.
-s 명명된 SQL Server인스턴스를 시작할 수 있습니다. -s 매개 변수를 설정하지 않으면 기본 인스턴스가 시작을 시도합니다. sqlservr.exe를 시작하기 전에 명령 프롬프트에서 해당 인스턴스에 적합한 BINN 디렉터리로 전환해야 합니다. 예를 들어 Instance1이 이진 파일에 대해 \mssql$Instance1을 사용할 경우, 사용자는 \mssql$Instance1\binn 디렉터리에서 sqlservr.exe -s instance1을 시작해야 합니다.
-Ttrace# 지정된 추적 플래그( SQL Server trace# ) 적용 시인스턴스를 시작해야 함을 나타냅니다. 추적 플래그는 비표준 동작으로 서버를 시작하는 데 사용합니다. 자세한 내용은 추적 플래그(Transact-SQL)를 참조하세요.

**중요**-T 옵션을 사용하여 추적 플래그를 지정할 때 대문자 "T"를 사용하여 추적 플래그 번호를 전달합니다. SQL Server에서는 소문자 "t"도 사용할 수 있지만 그럴 경우 SQL Server 지원 엔지니어에게만 필요한 다른 내부 추적 플래그가 설정됩니다. 제어판 시작 창에서 지정한 매개 변수를 읽을 수 없습니다.
-x 다음 모니터링 기능을 해제합니다.

SQL Server 성능 모니터 카운터

CPU 시간과 캐시 적중률 통계 유지

DBCC SQLPERF 명령에 대한 정보 수집

일부 동적 관리 뷰에 대한 정보 수집

여러 확장 이벤트 이벤트 지점



**경고**-x 시작 옵션을 사용하면 SQL Server 성능 및 기능 문제를 진단하는 데 사용할 수 있는 정보가 크게 줄어듭니다.
-E 파일 그룹의 각 파일에 할당되는 익스텐트의 수를 늘립니다. 이 옵션은 인덱스 또는 데이터 검색을 실행하는 사용자 수가 제한되는 데이터 웨어하우스 애플리케이션에 유용합니다. 성능에 부정적인 영향을 줄 수 있으므로 다른 애플리케이션에서는 이 옵션을 사용하면 안 됩니다. 이 옵션은 SQL Server32비트 릴리스에서는 지원되지 않습니다.

문제 해결을 위한 시작 옵션 사용

단일 사용자 모드 및 최소 구성 모드와 같은 일부 시작 옵션은 주로 문제 해결에서 사용됩니다. sqlservr.exe를 수동으로 시작하는 동안 명령줄에서 –m 또는 –f 옵션을 사용하여 문제 해결을 위해 서버를 시작하면 가장 간단합니다.

참고

SQL Server net start 를 사용하여를 시작하는 경우에는 시작 옵션에 하이픈(-) 대신 슬래시(/)를 사용합니다.

정상적인 작업 중 시작 옵션 사용

SQL Server를 시작할 때마다 사용하는 시작 옵션이 있을 수 있습니다. 이러한 옵션(예: -g 또는 추적 플래그로 시작)은 SQL Server 구성 관리자 사용하여 시작 매개 변수를 구성하여 가장 쉽게 수행할 수 있습니다. 이러한 도구는 시작 옵션을 레지스트리 키로 저장하여 SQL Server 가 항상 이 시작 옵션으로 시작할 수 있게 됩니다.

호환성 지원

-h 매개 변수는 SQL Server 2014에서 지원되지 않습니다. 이 매개 변수는 AWE를 사용할 때 핫 추가 메모리 메타데이터에 대한 가상 메모리 주소 공간을 예약하기 위해 이전 버전의 SQL Server 32비트 인스턴스에서 사용되었습니다. 자세한 내용은 SQL Server 2014에서 지원되지 않는 SQL Server 기능을 참조하세요.

scan for startup procs 서버 구성 옵션 구성

데이터베이스 엔진, SQL Server 에이전트 또는 SQL Server Browser 서비스 시작, 중지, 일시 중지, 재개 및 다시 시작

참고 항목

CHECKPOINT(Transact-SQL)
sqlservr 애플리케이션