microsoft / WSL

Issues found on WSL
https://docs.microsoft.com/windows/wsl
MIT License
17.47k stars 822 forks source link

WSL Sparse does not work at all. #12103

Open PeterTucker opened 1 month ago

PeterTucker commented 1 month ago

Windows Version

Microsoft Windows [Version 10.0.19045.4894]

WSL Version

2.2.4.0

Are you using WSL 1 or WSL 2?

Kernel Version

5.15.153.1-microsoft-standard-WSL2

Distro Version

Ubuntu 22.04

Other Software

No response

Repro Steps

Sparse does not work.

Ubuntu disk space (.vhdx file) shows 118gbs in windows 10. In Ubuntu: /ncdu / --exclude /mnt shows 64gbs

Powershell(admin): notepad "$env:USERPROFILE/.wslconfig" .wslconfig:

[experimental]
sparseVhd=true

Powershell(admin):

wsl --list # list distros
wsl --manage <distro> --set-sparse true # enable sparse on vdisk
wsl --shutdown # restart wsl
wsl # restart wsl 

Then when I check the size, it has not changed at all, still 118gbs.

SOLUTION (MANUAL SHRINKING):

for anyone who finds this in the future. Here is a way to resize the disk manually.

Powershell (admin):

FIRST BACKUP YOUR VHDX FILE
wsl --list # list distros
wsl --shutdown # Be patient and wait a bit for wsl to shutdown. It will eventually shutdown.
wsl --manage <DISTRO_NAME> --set-sparse false
optimize-vhd -Path "<VHDX_FILE>" -Mode full
wsl --manage <DISTRO_NAME> --set-sparse true

Then test if the VHDX file (wiztree) has shrunk and your distro can run.

Expected Behavior

Reclaim disk space in Windows 10.

Actual Behavior

The sparseVhd setting does not reclaim disk space in Windows 10.

Diagnostic Logs

No response

github-actions[bot] commented 1 month ago

Logs are required for review from WSL team

If this a feature request, please reply with '/feature'. If this is a question, reply with '/question'. Otherwise please attach logs by following the instructions below, your issue will not be reviewed unless they are added. These logs will help us understand what is going on in your machine.

How to collect WSL logs Download and execute [collect-wsl-logs.ps1](https://github.com/Microsoft/WSL/blob/master/diagnostics/collect-wsl-logs.ps1) in an **administrative powershell prompt**: ``` Invoke-WebRequest -UseBasicParsing "https://raw.githubusercontent.com/microsoft/WSL/master/diagnostics/collect-wsl-logs.ps1" -OutFile collect-wsl-logs.ps1 Set-ExecutionPolicy Bypass -Scope Process -Force .\collect-wsl-logs.ps1 ``` The script will output the path of the log file once done. If this is a networking issue, please use [collect-networking-logs.ps1](https://github.com/Microsoft/WSL/blob/master/diagnostics/collect-networking-logs.ps1), following the instructions [here](https://github.com/microsoft/WSL/blob/master/CONTRIBUTING.md#collect-wsl-logs-for-networking-issues) Once completed please upload the output files to this Github issue. [Click here for more info on logging](https://github.com/microsoft/WSL/blob/master/CONTRIBUTING.md#8-collect-wsl-logs-recommended-method) If you choose to email these logs instead of attaching to the bug, please send them to wsl-gh-logs@microsoft.com with the number of the github issue in the subject, and in the message a link to your comment in the github issue and reply with '/emailed-logs'.

View similar issues

Please view the issues below to see if they solve your problem, and if the issue describes your problem please consider closing this one and thumbs upping the other issue to help us prioritize it!

Open similar issues:

Closed similar issues:

Note: You can give me feedback by thumbs upping or thumbs downing this comment.

PeterTucker commented 1 month ago

/question

PeterTucker commented 1 month ago

Why does it not work?

github-actions[bot] commented 1 month ago
Diagnostic information ``` Found '/question', adding tag 'question' ```
elsaco commented 1 month ago

@PeterTucker after wsl --manage <DISTRO_NAME> --set-sparse false do a wsl --shutdown again, and it should work.

Notice the FileSize before and after running the command:

PS C:\Users\elsaco> Get-VHD -Path "G:\vms\sid\ext4.vhdx"

ComputerName            : ELEVEN
Path                    : G:\vms\sid\ext4.vhdx
VhdFormat               : VHDX
VhdType                 : Dynamic
FileSize                : 1081081856
Size                    : 549453824000
MinimumSize             :
LogicalSectorSize       : 512
PhysicalSectorSize      : 4096
BlockSize               : 1048576
ParentPath              :
DiskIdentifier          : 40545B0A-6EE6-483B-AE7D-B64B4EF39DB1
FragmentationPercentage : 100
Alignment               : 1
Attached                : False
DiskNumber              :
IsPMEMCompatible        : False
AddressAbstractionType  : None
Number                  :

PS C:\Users\elsaco> Optimize-VHD -Path "G:\vms\sid\ext4.vhdx" -Mode full
PS C:\Users\elsaco> Get-VHD -Path "G:\vms\sid\ext4.vhdx"

ComputerName            : ELEVEN
Path                    : G:\vms\sid\ext4.vhdx
VhdFormat               : VHDX
VhdType                 : Dynamic
FileSize                : 1067450368
Size                    : 549453824000
MinimumSize             :
LogicalSectorSize       : 512
PhysicalSectorSize      : 4096
BlockSize               : 1048576
ParentPath              :
DiskIdentifier          : 40545B0A-6EE6-483B-AE7D-B64B4EF39DB1
FragmentationPercentage : 100
Alignment               : 1
Attached                : False
DiskNumber              :
IsPMEMCompatible        : False
AddressAbstractionType  : None
Number