繁体   English   中英

Amazon EC2中的磁盘空间不足,无法找到我正在使用的存储空间

[英]Running out of disk space in Amazon EC2, can't find what I am using my storage for

我正在使用美国东部的T2.large实例运行AWS ami。 我试图上传一些数据然后在终端上运行:

df -h

我得到了这个结果:

Filesystem      Size  Used Avail Use% Mounted on
udev            3.9G     0  3.9G   0% /dev
tmpfs           799M  8.6M  790M   2% /run
/dev/xvda1      9.7G  9.6G   32M 100% /
tmpfs           3.9G     0  3.9G   0% /dev/shm
tmpfs           5.0M     0  5.0M   0% /run/lock
tmpfs           3.9G     0  3.9G   0% /sys/fs/cgroup
tmpfs           799M     0  799M   0% /run/user/1000

我知道我没有向实例上传9.7 GB的数据,但我不知道/dev/xvda1是什么或如何访问它。

我还假设所有tmpfs都是临时文件,我该如何删除它们?

我回答了一些问题,我跑了

sudo du -sh /*

我得到了:

16M /bin
124M    /boot
0   /dev
6.5M    /etc
2.7G    /home
0   /initrd.img
0   /initrd.img.old
4.0K    /jupyterhub_cookie_secret
16K /jupyterhub.sqlite
268M    /lib
4.0K    /lib64
16K /lost+found
4.0K    /media
4.0K    /mnt 
562M    /opt
du: cannot access '/proc/15616/task/15616/fd/4': No such file or directory
du: cannot access '/proc/15616/task/15616/fdinfo/4': No such file or directory
du: cannot access '/proc/15616/fd/4': No such file or directory
du: cannot access '/proc/15616/fdinfo/4': No such file or directory
0   /proc
28K /root
8.6M    /run
14M /sbin
8.0K    /snap 
8.0K    /srv
0   /sys
64K /tmp
4.7G    /usr
1.5G    /var
0   /vmlinuz
0   /vmlinuz.old

/dev/xvda1是您的根卷。 您列出的AMI的默认根卷大小为20GB如下所示:

描述图像并获取它的块设备映射:

aws ec2 describe-images --image-ids ami-3b0c205e --region us-east-2 | jq .Images[].BlockDeviceMappings[]

查看卷大小

{
  "DeviceName": "/dev/sda1",
  "Ebs": {
    "Encrypted": false,
    "DeleteOnTermination": true,
    "VolumeType": "gp2",
    "VolumeSize": 20,
    "SnapshotId": "snap-03341b1ff8ee47eaa"
  }
}
{
  "DeviceName": "/dev/sdb",
  "VirtualName": "ephemeral0"
}
{
  "DeviceName": "/dev/sdc",
  "VirtualName": "ephemeral1"
}

以正确的20GB卷大小启动时,有足够的可用空间(10GB)

root@ip-10-100-0-64:~# df -h
Filesystem      Size  Used Avail Use% Mounted on
udev            488M     0  488M   0% /dev
tmpfs           100M  3.1M   97M   4% /run
/dev/xvda1       20G  9.3G   11G  49% /
tmpfs           496M     0  496M   0% /dev/shm
tmpfs           5.0M     0  5.0M   0% /run/lock
tmpfs           496M     0  496M   0% /sys/fs/cgroup
tmpfs           100M     0  100M   0% /run/user/1000

看来这里的问题是实例是以10GB (不知何故,我认为这不可能)的存储而不是默认的20GB

当你用完根文件系统空间,并且没有做任何你知道消耗空间的事情时,99%的时间(+/- 98%)它是一个日志文件。 运行这个:

sudo du -s /var/log/* | sort -n

您将在/var/log (这是Linux系统的标准日志记录目标)中看到所有子目录的列表,最后您可能会看到旁边有一个非常大的数字的条目。 如果你没有看到任何东西,那么下一个尝试的地方是/tmp (我用du -sh /tmp做,因为它打印一个带有“人类”缩放的数字)。 如果这不起作用,那么你需要在文件系统的根目录上运行原始命令/* (这可能需要一些时间)。

假设它是一个日志文件,那么你应该看一下它,看看相关应用程序中是否有错误。 如果没有,您可能只需要了解logrotate

/ dev / xvda1是亚马逊存储系统上基于磁盘的存储。

它是您系统上唯一的存储器,它包含您的操作系统和所有数据。 所以我猜Ubuntu安装使用的大部分空间

请记住:亚马逊的T实例根本没有任何本地磁盘。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM