Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

"Docker Desktop is switching..." 메시지와 DockerDesktopVM CPU 소비 현상

그러니까, Docker Desktop의 모드를 "Linux Container" / "Windows Container" 간에 몇 번 스위칭을 했는데 어느 순간부터 아무리 기다려도 스위칭이 안 되고 "Docker Desktop is switching..."이라는 메시지만 나옵니다.

그 순간의 Hyper-V 관리자를 보면 다음과 같이 "DockerDesktopVM"의 CPU 소비가 높은 현상이 있는데요.

docker_vm_cpu_high_1.png

어쩔 수 없이 강제 종료 후 다시 Docker Desktop을 실행시켰는데 이번에는 "Docker Desktop is starting..." 문구가 보이고 마찬가지로 DockerDesktopVM의 CPU가 올라갑니다.

검색해 보면 다음의 글이 나오는데,

Windows 10 Docker processes consuming high CPU with no running containers
; https://github.com/docker/for-win/issues/1772

덧글 중에 보면,

Happyman0815 commented on Feb 22, 2019

I just un-checked "Expose Docker Deamon on TCP ... without TLS") via the Docker Desktop Settings GUI and then closed Docker Desktop.
vmmem.exe stopped consuming CPU after this step. It is not even appearing in the task manager anymore.


라는 글이 나오는데요. 설마 하면서도 별다른 대책이 없어 해봤는데... ^^; 정말 CPU high 문제가 사라지고 Docker Desktop도 정상적으로 구동이 되었습니다. 일단 저 옵션을 변경 후 제대로 동작하기만 하면 다시 옵션을 제거해도 그런 현상은 없었습니다.

단지, Docker Desktop이 좀 안정적이지 못한 부분이 있는 것 같은데, 문제 재현을 위해 "Linux Container" / "Windows Container" 간의 스위칭을 하다 보면 다시 그런 현상이 발생했고, 역시나 "Expose Docker Deamon on TCP ... without TLS" 옵션을 설정하면 정상적으로 구동이 되었습니다.




참고로, 저런 현상이 발생할 때는 Docker Desktop의 설정 화면을 열 수 없으므로 "Expose Docker Deamon on TCP ... without TLS" 옵션을 UI로 설정할 수는 없습니다. 대신 docker 관련 모든 프로세스를 (강제) 종료한 후, 다음의 경로에 있는 설정 파일을 열어,

%USERPROFILE%\AppData\Roaming\Docker\settings.json

이렇게 수정하면 됩니다. (반드시 Linux Container 모드로 시작하도록, TCP 2375를 활성화하는 방식이어야 합니다.)

...[생략]...
  "useWindowsContainers": false,
...[생략]...
  "exposeDockerAPIOnTCP2375": true,
...[생략]...




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/7/2020]

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

비밀번호

댓글 작성자
 




... 136  137  138  [139]  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1579정성태1/12/201422261오류 유형: 207. System.ArgumentException was unhandled - Message=[net_WebHeaderInvalidControlChars]
1578정성태1/11/201433828개발 환경 구성: 209. Fiddler에서 WebSocket 통신을 모니터링하는 방법 [1]
1577정성태1/11/201424013오류 유형: 206. WriteFile Win32API 사용 시 비정상 종료 현상 [3]
1576정성태1/11/201441975Windows: 81. 긴 이름의 파일/폴더 삭제하는 법 [5]
1575정성태1/11/201422458오류 유형: 205. Exception calling "Provision" with "0" argument(s): "The timer job did not complete running within the allotted time."
1574정성태1/11/201424451오류 유형: 204. An unhandled exception ('System.Security.Cryptography.CryptographicException') occurred in OWSTIMER.EXE
1573정성태1/11/201422195오류 유형: 203. 이벤트 로그 에러 - MsiInstaller에서 Chart Controls 설치 관련 오류 발생
1572정성태1/9/201425729.NET Framework: 406. CoreLab - OraDirect .NET 사용법
1571정성태1/9/201421927.NET Framework: 405. override 메서드가 정의된 타입의 인스턴스로 base 메서드를 호출하는 방법 - 두 번째 이야기
1570정성태1/9/201425323Math: 11. C# 시뮬레이션 - 몬티홀 게임파일 다운로드1
1569정성태1/8/201422521Windows: 80. 윈도우 서버 백업의 복원하는 옵션 설명
1568정성태1/8/201423099오류 유형: 202. Hyper-V 서비스 시작 오류 - Not enough storage is available to complete this operation.
1567정성태1/8/201492440기타: 40. 오피스 2013 라이선스 리셋하는 방법 [5]
1566정성태1/7/201423414Windows: 79. 윈도우 8 - 스카이드라이브(skydrive)의 Online/Offline 동기화 방식 [1]
1565정성태1/3/201421886.NET Framework: 404. 리플렉션을 이용해 닷넷 LicenseManager를 우회할 수 있는 사례
1564정성태1/3/201422421.NET Framework: 403. override 메서드가 정의된 타입의 인스턴스로 base 메서드를 호출하는 방법파일 다운로드1
1563정성태1/3/201428137오류 유형: 201. ASP.NET 웹 사이트를 IIS 7 이상의 환경에서 호스팅할 때 500 오류 발생
1562정성태1/2/201432782.NET Framework: 402. 카카오톡 PC 버전 실행 시 개발자 컴퓨터에서 Themida 오류 나는 문제 - 두 번째 이야기
1561정성태1/1/201442321오류 유형: 200. 카카오톡 PC 버전 실행 시 개발자 컴퓨터에서 Themida 오류 나는 문제 [2]
1560정성태1/1/201421133오류 유형: 199. Hyper-V - Checkpoint 생성 오류
1559정성태12/30/201324362.NET Framework: 401. windbg에서 확인해 보는 관리 힙의 인스턴스 구조 [2]
1558정성태12/29/201333851.NET Framework: 400. 눈으로 확인하는 LayoutKind 옵션 효과 [2]파일 다운로드1
1557정성태12/27/201322877.NET Framework: 399. LayoutKind 옵션에 대해 [2]
1556정성태12/27/201343165개발 환경 구성: 208. IIS + Node.js 환경 구성 [8]
1555정성태12/27/201329919개발 환경 구성: 207. IIS의 80 포트를 공유하는 응용 프로그램 만드는 방법 [1]
1554정성태12/26/201335299Windows: 78. 마음에 드는 윈도우 8.1 태블릿 - 델 베뉴 8 프로 5830 [4]
... 136  137  138  [139]  140  141  142  143  144  145  146  147  148  149  150  ...