Microsoft MVP성태의 닷넷 이야기
오류 유형: 269. USB 메모리의 용량이 비정상적으로 보여진다면? [링크 복사], [링크+제목 복사],
조회: 30759
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

USB 메모리의 용량이 비정상적으로 보여진다면?

8GB 용량의 USB 디스크가 2MB로 표시된다면서 지인으로부터 해당 현상이 발생한 USB 장치를 하나 건네 받았습니다. 오호~~~ 재미있군요. ^^

실제로 윈도우 탐색기를 통해 확인해 보니 정말 2MB 정도의 용량만 표시되었습니다.

usb_storage_1.png

이걸 보고, 순간 의심을 한 것은 바로 파티션이었습니다. "컴퓨터 관리" 관리 콘솔을 띄우고 "Disk Management" 영역에서 해당 USB의 현황을 보니 정말 그 문제가 맞았습니다.

usb_storage_2.png

보시는 바와 같이 중간 부분만 FAT 형식의 파티션으로 나뉘어져 있는데... 참으로 희한하군요. 저렇게 파티션을 일부러 나누려고 해도 힘들 것 같습니다. ^^;

더욱 재미있는 것은, 저 상태에서 앞/뒤 파티션의 확장이라든지 해당 파티션을 지우는 기능이 비활성화되었다는 점입니다. 따라서, 이 문제를 해결하려면 좀 더 저수준의 동작이 필요했습니다. 바로 diskpart.exe를 사용하는 것! (diskpart는 Windows 2000부터 제공되는 유틸리티로 기존의 fdisk를 대체하는 프로그램입니다.)

그럼, (관리자 권한으로) diskpart.exe를 실행하고 "list volume" 명령을 통해 우리가 변경하려는 볼륨을 "select volume [number]" 명령어로 선택해 줍니다.

C:\WINDOWS\system32>diskpart

Microsoft DiskPart version 6.3.9600

Copyright (C) 1999-2013 Microsoft Corporation.
On computer: THEMYTH8

DISKPART> list volume

  Volume ###  Ltr  Label        Fs     Type        Size     Status     Info
  ----------  ---  -----------  -----  ----------  -------  ---------  --------
  Volume 0     F                       DVD-ROM         0 B  No Media
  Volume 1     C                NTFS   Partition     98 GB  Healthy    Boot
  Volume 2     D   New Volume   NTFS   Partition     42 GB  Healthy
  Volume 3     E   New Volume   NTFS   Partition     97 GB  Healthy    Pagefile
  Volume 4         Recovery     NTFS   Partition    300 MB  Healthy    Hidden
  Volume 5                      FAT32  Partition    100 MB  Healthy    System
  Volume 6     G                FAT    Removable   2272 KB  Healthy

DISKPART> select volume 6

Volume 6 is the selected volume.

DISKPART> list volume

  Volume ###  Ltr  Label        Fs     Type        Size     Status     Info
  ----------  ---  -----------  -----  ----------  -------  ---------  --------
  Volume 0     F                       DVD-ROM         0 B  No Media
  Volume 1     C                NTFS   Partition     98 GB  Healthy    Boot
  Volume 2     D   New Volume   NTFS   Partition     42 GB  Healthy
  Volume 3     E   New Volume   NTFS   Partition     97 GB  Healthy    Pagefile
  Volume 4         Recovery     NTFS   Partition    300 MB  Healthy    Hidden
  Volume 5                      FAT32  Partition    100 MB  Healthy    System
* Volume 6     G                FAT    Removable   2272 KB  Healthy

DISKPART> list disk

  Disk ###  Status         Size     Free     Dyn  Gpt
  --------  -------------  -------  -------  ---  ---
  Disk 0    Online          238 GB  1024 KB        *
  Disk 1    Online           14 GB      0 B
* Disk 2    Online         7728 MB      0 B

"select volume [number]" 명령을 실행한 후에는 반드시 자신이 원하는 volume이 선택되었는지를 "list volume" 명령어로 확인하는 습관을 들이는 것이 좋습니다. 위에서 보는 바와 같이 선택된 볼륨에 대해서는 "*" 표시가 붙게 됩니다.

이 상태에서 2272KB 용량으로 할당된 FAT 파티션을 다음과 같이 삭제할 수 있습니다.

DISKPART> delete partition

DiskPart successfully deleted the selected partition.

DISKPART> list partition

There are no partitions on this disk to show.

그리곤, "list partition" 명령으로 파티션이 삭제되었음을 확인해 줍니다. 자... 그 다음은 디스크 용량에 꽉차게 새로운 파티션을 만들어 주면 됩니다. 다음과 같이!

DISKPART> create partition primary

DiskPart succeeded in creating the specified partition.

DISKPART> list partition

  Partition ###  Type              Size     Offset
  -------------  ----------------  -------  -------
* Partition 1    Primary           7727 MB  1024 KB

그럼, 7727MB... 거의 8GB 용량의 파티션이 잡힌 것을 확인할 수 있습니다. 여기까지 되었으면 탐색기나 "컴퓨터 관리자" 관리 콘솔에도 정상적으로 USB 디스크가 나오게 됩니다. 물론, 포맷도 할 수 있고.

저는 그냥 diskpart에서 포맷까지 함께 해버렸습니다.

DISKPART> format fs=FAT32 QUICK

문제 해결 끝!




참고로, format 명령어 시에 다음과 같이 오류가 발생할 수 있습니다.

DISKPART> format fs=NTFS  QUICK

    0 percent completed

DiskPart has encountered an error: The parameter is incorrect.
See the System Event Log for more information.

이런 오류가 발생하는 경우는, 해당 디스크에 파티션이 없는 경우라고 보시면 됩니다. "list partition" 명령어로 확인해 보시고, 이후 파티션 생성을 해주면 정상 동작합니다.





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







[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 



2015-02-03 07시38분
[Lyn] 혹시 보안USB 같은 거엿는데 포맷해버린거 아닌가요 ㅋ
[guest]
2015-02-04 12시14분
일반 USB라서 그런 건 아닌 듯 한데... 암튼... 사용자들의 활용 방법은 상상을 초월하는 것 같습니다. ^^
정성태
2016-03-25 05시37분
[hebal] 정말 유용한 정보 감사합니다 덕분에 삽질 피했습니다.
[guest]
2016-07-18 03시59분
[guest] 덕분에 문제 해결했습니다. 감사합니다!
[guest]
2016-12-04 03시01분
[시민] USB 날아간줄 알고 새로 사야되나 하고 있었는데 덕분에 잘 해결됬습니다. 감사합니다!
[guest]
2016-12-07 08시06분
[정환나라] USB에 리눅스 같은걸 깔아도 그럴수 있습니다.
제가 라즈베리파이에 리눅스 설치해서 뭐 하다가 Win10core iot 설치하려하니 안되서
SDFormatter 같은 프로그램으로 다시 포멧한 경우도 있구요.
[guest]
2017-01-02 02시47분
[guest] 문제 잘 해결했습니다~ 리눅스 깔고나니 이런 증상이 생기네요 ㅎㅎ
[guest]

... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11811정성태2/11/201920796오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제
11810정성태2/11/201918492.NET Framework: 808. .NET Profiler - GAC 모듈에서 GAC 비-등록 모듈을 참조하는 경우의 문제
11809정성태2/11/201920625.NET Framework: 807. ClrMD를 이용해 메모리 덤프 파일로부터 특정 인스턴스를 참조하고 있는 소유자 확인
11808정성태2/8/201921948디버깅 기술: 123. windbg - 닷넷 응용 프로그램의 메모리 누수 분석
11807정성태1/29/201919846Windows: 156. 가상 디스크의 용량을 복구 파티션으로 인해 늘리지 못하는 경우 [4]
11806정성태1/29/201919520디버깅 기술: 122. windbg - 덤프 파일로부터 PID와 환경 변수 등의 정보를 구하는 방법
11805정성태1/28/201921623.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]파일 다운로드1
11804정성태1/24/201919516Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우
11803정성태1/10/201918363디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상
11802정성태1/7/201920102.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)파일 다운로드1
11801정성태1/1/201921436개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]
11800정성태12/28/201820501오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error
11799정성태12/19/201822223.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]파일 다운로드1
11798정성태12/19/201821064개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"
11797정성태12/19/201817076개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류
11796정성태12/19/201817311개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법
11795정성태12/19/201820619Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]
11794정성태12/16/201816712오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.
11793정성태12/16/201819270개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법 [1]
11792정성태12/11/201819071Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting파일 다운로드1
11791정성태12/11/201819077VS.NET IDE: 130. C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [1]
11790정성태12/11/201817587오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied.
11789정성태12/10/201831177Windows: 153. C# - USB 장치의 연결 및 해제 알림을 위한 WM_DEVICECHANGE 메시지 처리 [2]파일 다운로드2
11788정성태12/4/201817435오류 유형: 506. SqlClient - Value was either too large or too small for an Int32.Couldn't store <2151292191> in ... Column
11787정성태11/29/201821592Graphics: 33. .NET으로 구현하는 OpenGL (9), (10) - OBJ File Format, Loading 3D Models파일 다운로드1
11786정성태11/29/201818566오류 유형: 505. OpenGL.NET 예제 실행 시 "Managed Debugging Assistant 'CallbackOnCollectedDelegate'" 예외 발생
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...