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

docker - c:\programdata\docker\windowsfilter 폴더 정리하는 방법

Windows Containers 관련 폴더는 함부로 지우면 안 됩니다. 왜냐하면, 로컬 PC 환경과 밀접하게 연결되어 있기 때문에 자칫 잘못하면 로컬 PC 환경까지 깨지게 됩니다. 예를 들어, "c:\programdata\docker\windowsfilter" 폴더 같은 경우 임의로 삭제를 하는 경우 그와 연결된 사용자 바탕 화면의 데이터까지 모두 날아갑니다.

문제는, docker(및 그 이미지들)과 windows containers를 모두 삭제했는데도 여전히 "c:\programdata\docker\windowsfilter" 폴더는 수십 GB를 점유하고 있다는 점입니다. 함부로 지워서도 안되고, 그냥 두기도 뭐 하고. ^^;

다행히 검색해 보면 답이 나옵니다.

[Windows] windowsfilter folder impossible to delete 
; https://github.com/docker/docker/issues/26873

답변에 보면, 다음의 zap 프로그램을 소개합니다.

jhowardmsft/docker-ci-zap
; https://github.com/jhowardmsft/docker-ci-zap

아쉽게도 빌드된 유형이 아니고 Go 언어로 된 소스 코드라서 문제가 복잡합니다.

우선 Go 컴파일러부터 설치하는데,

Download the Go distribution
; https://golang.org/doc/install

설치 프로그램에서 c:\go\bin에 대한 환경 변수 등록을 해주긴 하는데 시스템에 변경 사항을 알리는 기능이 없어서 수작업으로 다시 시스템 환경 변수를 업데이트해주던가 아니면 다시 '로그인'을 해야 합니다.

그다음 gcc 컴파일러를 설치해야 하는데, Go 언어 자체에서는 필요 없지만 우리가 컴파일해야 할 zap을 위해서는 필요하기 때문에 다운로드 받아야 합니다. (Go 컴파일러가 64비트이므로 반드시 MinGW 64로 설치해야 합니다.)

MinGW-w64 - for 32 and 64 bit Windows 
; https://sourceforge.net/projects/mingw-w64/

설치 후, gcc.exe가 있는 "C:\Program Files\mingw-w64\x86_64-6.2.0-win32-seh-rt_v5-rev1\mingw64\bin" 폴더를 시스템 환경 변수의 PATH에 등록해 줍니다.

그다음, (제 경우에는) 다음의 폴더를 만든 후,

E:\gowork\src\github.com\stjeong\hello

환경 변수에 GOPATH=E:\gowork 설정을 추가하고 다음과 같이 컴파일 해주면 됩니다.

E:\gowork>go install github.com/stjeong/zap

그런데, 이렇게만 해주면 github.com/microsoft/hcsshim 등의 패키지가 없다고 나옵니다. 그럼, 그에 해당하는 경로로 go get 명령어를 해줍니다.

go get github.com/microsoft/hcsshim

컴파일이 되면 e:\gowork\bin 폴더에 zap.exe 파일이 생성됩니다. 관리자 권한의 cmd.exe 명령행을 실행하고 다음과 같이 수행해 주면,

zap -folder "C:\ProgramData\docker"

정상적으로 "C:\ProgramData\docker" 폴더 하위의 모든 내용들이 정리됩니다.

(혹시, 저 과정들이 싫다면 그냥 제가 첨부한 zap.exe 파일을 다운로드받아 실행하면 됩니다.)




참고로, 다음과 같은 오류가 발생하면,

E:\gowork>go install github.com/stjeong/zap
# github.com/microsoft/hcsshim
cc1.exe: sorry, unimplemented: 64-bit mode not compiled in

mingw 32비트가 설치한 경우입니다. gcc.exe가 32비트여서 go.exe의 64비트와 맞지 않아 발생하는 문제입니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 9/25/2016]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12198정성태3/17/202011714오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202010870VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/20208820오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202010517.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202012857오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/20209516개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202011978개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202012318개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/20208514오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/202013323개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202015504Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/20208256오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/20209347오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
12185정성태3/11/20209989오류 유형: 603. The browser service was unable to retrieve a list of servers from the browser master...
12184정성태3/11/202011457오류 유형: 602. Automatic certificate enrollment for local system failed (0x800706ba) The RPC server is unavailable. [3]
12183정성태3/11/20209795오류 유형: 601. Warning: DsGetDcName returned information for \\[...], when we were trying to reach [...].
12182정성태3/11/202011043.NET Framework: 901. C# Windows Forms - Vista/7 이후의 Progress Bar 업데이트가 느린 문제파일 다운로드1
12181정성태3/11/202011879기타: 76. 재현 가능한 최소한의 예제 프로젝트란? - 두 번째 예제파일 다운로드1
12180정성태3/10/20208476오류 유형: 600. "Docker Desktop for Windows" - EXPOSE 포트가 LISTENING 되지 않는 문제
12179정성태3/10/202019865개발 환경 구성: 481. docker - PostgreSQL 컨테이너 실행
12178정성태3/10/202011340개발 환경 구성: 480. Linux 운영체제의 docker를 위한 tcp 바인딩 추가 [1]
12177정성태3/9/202011018개발 환경 구성: 479. docker - MySQL 컨테이너 실행
12176정성태3/9/202010437개발 환경 구성: 478. 파일의 (sha256 등의) 해시 값(checksum) 확인하는 방법
12175정성태3/8/202010519개발 환경 구성: 477. "Docker Desktop for Windows"의 "Linux Container" 모드를 위한 tcp 바인딩 추가
12174정성태3/7/202010064개발 환경 구성: 476. DockerDesktopVM의 파일 시스템 접근 [3]
12173정성태3/7/202011060개발 환경 구성: 475. docker - SQL Server 2019 컨테이너 실행 [1]
... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...