Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

NT 서비스 시작 시 "Error 1067: The process terminated unexpectedly." 오류 발생

희한한 일입니다. 고객사의 특정 서버에서 NT 서비스가 실행되지 않습니다. 서비스의 설치까지는 잘 되었는데, 서비스 관리자에서 실행하면 다음과 같은 오류가 발생합니다.

Windows could not start the TestMyService service on Local Computer.

Error 1067: The process terminated unexpectedly.

"net start"로 해도 마찬가지입니다.

D:\temp>net start TestMyService 
The TestMyService service is starting.
The TestMyService service could not be started.

A system error has occurred.

System error 1067 has occurred.

The process terminated unexpectedly.

원인 파악을 위해 이벤트 로그를 봤는데, 웬일인지 그에 대한 이벤트 로그도 전혀 남지 않습니다. 보통, NT 서비스는 실패를 하더라도 SCM(Service Control Manager) 측에서 서비스를 실행하려 한다는 이벤트 로그가 다음과 같은 식으로 남게 마련입니다.

Log Name:      System
Source:        Service Control Manager
Date:          2017-07-02 오전 2:07:00
Event ID:      7036
Task Category: None
Level:         Information
Keywords:      Classic
User:          N/A
Computer:      TESTPC
Description:
The Adobe Flash Player Update Service service entered the running state.

그런데 자세히 보니 이벤트 로그에 있는 항목들의 날짜가 수상합니다. 과거의 어느 날짜 이후로는 이벤트 항목이 전혀 생성되어 있지 않았던 것입니다. 혹시나 싶어 해당 범주의 이벤트 로그에 대한 속성을 보니 다음과 같이 꽉 차 있는 상태였습니다.

service_not_started_when_event_full_1.png

(참고로, 위의 "Maximum log size"는 1028로 재현을 위해 일부러 낮게 설정된 것으로 실제 고객사의 최대 크기는 크게 잡혀 있었습니다.)

윈도우 운영체제를 기본 설치한 경우, 원래는 위의 옵션에서 "When maximum event log size is reached:"의 값이 "Overwrite events as needed (oldest events first)"이기 때문에 용량이 찬 경우 덮어써지게 되어 있습니다. 그런데, 저 값을 서버 담당자가 어떤 사유로 인해 바꾼 것이고 결국 서비스 시작이 안되는 상황까지 발생한 것입니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/6/2017]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2020-07-21 08시52분
[웅] 사진이 안보입니다 ㅠ

When maximum event log size is reached 옵션을 다시 바꿔주면 해결되는게 맞는건지요?
[guest]
2020-07-21 09시04분
@웅 넵 맞습니다. ^^ (그림이 안 보이는 걸 몰랐는데, 제보해 주셔서 감사합니다. ^^)
정성태

... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12455정성태12/15/20208768오류 유형: 693. DLL 로딩 시 0x800704ec - This Program is Blocked by Group Policy
12454정성태12/15/20209369Windows: 184. Windows - AppLocker의 "DLL Rules"를 이용해 임의 경로에 설치한 DLL의 로딩을 막는 방법 [1]
12453정성태12/14/202010299.NET Framework: 984. C# - bool / BOOL / VARIANT_BOOL에 대한 Interop [1]파일 다운로드1
12452정성태12/14/202010527Windows: 183. 설정은 가능하지만 구할 수는 없는 TcpTimedWaitDelay 값
12451정성태12/14/20209686Windows: 182. WMI Namespace를 열거하고, 그 안에 정의된 클래스를 열거하는 방법 [5]
12450정성태12/13/202010403.NET Framework: 983. C# - TIME_WAIT과 ephemeral port 재사용파일 다운로드1
12449정성태12/11/202010801.NET Framework: 982. C# - HttpClient에서의 ephemeral port 재사용 [2]파일 다운로드1
12448정성태12/11/202012430.NET Framework: 981. C# - HttpWebRequest, WebClient와 ephemeral port 재사용파일 다운로드1
12447정성태12/10/202010570.NET Framework: 980. C# - CopyFileEx API 사용 예제 코드파일 다운로드1
12446정성태12/10/202011220.NET Framework: 979. C# - CoCreateInstanceEx 사용 예제 코드파일 다운로드1
12445정성태12/8/20208611오류 유형: 692. C# Marshal.PtrToStructure - The structure must not be a value class.파일 다운로드1
12444정성태12/8/20209408.NET Framework: 978. C# - GUID 타입 전용의 UnmanagedType.LPStruct [1]파일 다운로드1
12443정성태12/8/20209301.NET Framework: 977. C# PInvoke - C++의 매개변수에 대한 마샬링을 tlbexp.exe를 이용해 확인하는 방법
12442정성태12/4/20208153오류 유형: 691. Visual Studio - Build Events에 robocopy를 사용할때 "Invalid Parameter #1" 오류가 발행하는 경우
12441정성태12/4/20207814오류 유형: 690. robocopy - ERROR : No Destination Directory Specified.
12440정성태12/4/20208848오류 유형: 689. SignTool Error: Invalid option: /as
12439정성태12/4/202010109디버깅 기술: 176. windbg - 특정 Win32 API에서 BP가 안 걸리는 경우 (2) [1]
12438정성태12/2/202010065오류 유형: 688. .Visual C++ - Error C2011 'sockaddr': 'struct' type redefinition
12437정성태12/1/20209733VS.NET IDE: 155. pfx의 암호 키 파일을 Visual Studio 없이 등록하는 방법
12436정성태12/1/202010027오류 유형: 687. .NET Core 2.2 빌드 - error MSB4018: The "RazorTagHelper" task failed unexpectedly.
12435정성태12/1/202015478Windows: 181. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (4) - ReuseUnicastPort를 이용한 포트 고갈 문제 해결 [1]파일 다운로드1
12434정성태11/30/202010786Windows: 180. C# - dynamicport 값의 범위를 알아내는 방법
12433정성태11/29/20209832Windows: 179. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (3) - SO_PORT_SCALABILITY파일 다운로드1
12432정성태11/29/202011235Windows: 178. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 (2) - SO_REUSEADDR [1]파일 다운로드1
12431정성태11/27/20209167.NET Framework: 976. UnmanagedCallersOnly + C# 9.0 함수 포인터 사용 시 x86 빌드에서 오동작하는 문제파일 다운로드1
12430정성태11/27/20209907오류 유형: 686. Ubuntu - E: The repository 'cdrom://...' does not have a Release file.
... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...