这就是问题:
root@ip-10-126-247-82:~# mkfs.ext4 /dev/xvda3
mke2fs 1.41.14 (22-Dec-2010)
/dev/xvda3 is mounted; will not make a filesystem here!
调试如下:
root@ip-10-126-247-82:~# mount
/dev/xvda1 on / type ext4 (rw)
proc on /proc type proc (rw,noexec,nosuid,nodev)
sysfs on /sys type sysfs (rw,noexec,nosuid,nodev)
fusectl on /sys/fs/fuse/connections type fusectl (rw)
none on /sys/kernel/debug type debugfs (rw)
none on /sys/kernel/security type securityfs (rw)
udev on /dev type devtmpfs (rw,mode=0755)
devpts on /dev/pts type devpts (rw,noexec,nosuid,gid=5,mode=0620)
tmpfs on /run type tmpfs (rw,noexec,nosuid,size=10%,mode=0755)
none on /run/lock type tmpfs (rw,noexec,nosuid,nodev,size=5242880)
none on /run/shm type tmpfs (rw,nosuid,nodev)
此外,设备 /dev/xvda2 内核将重新格式化,而 xvda1、xvda2、xvda3 是不同的设备
root@ip-10-126-247-82:~# ls -la /dev/xvda*
brw-rw---- 1 root disk 202, 1 2011-12-21 18:54 /dev/xvda1
brw-rw---- 1 root disk 202, 2 2011-12-22 10:33 /dev/xvda2
brw-rw---- 1 root disk 202, 3 2011-12-21 18:54 /dev/xvda3
root@ip-10-126-247-82:~# cat /proc/partitions
major minor #blocks name
202 1 10485760 xvda1
202 2 356485632 xvda2
202 3 917504 xvda3
它不会格式化 xvda1(正确)
root@ip-10-126-247-82:~# mkfs.ext4 /dev/xvda1
mke2fs 1.41.14 (22-Dec-2010)
/dev/xvda1 is mounted; will not make a filesystem here!
它将格式化 xvda2(正确)
root@ip-10-126-247-82:~# mkfs.ext4 /dev/xvda2
mke2fs 1.41.14 (22-Dec-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
22282240 inodes, 89121408 blocks
4456070 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=0
2720 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
4096000, 7962624, 11239424, 20480000, 23887872, 71663616, 78675968
Writing inode tables: done
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done
This filesystem will be automatically checked every 36 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
它不会格式化 xvda3(不正确)
root@ip-10-126-247-82:~# mkfs.ext4 /dev/xvda3
mke2fs 1.41.14 (22-Dec-2010)
/dev/xvda3 is mounted; will not make a filesystem here!
- 编辑:
按照@Janne Pikkarainen 的建议添加 lsof debug:
root@ip-10-126-247-82:~# lsof -n | grep '202,3'
root@ip-10-126-247-82:~# lsof -n | grep 'xvda3'
root@ip-10-126-247-82:~#
答案1
看起来该挂载点是为了交换。
我以为自己在处理 m1.large,但实际上我在处理 c1.medium,它只有1 个临时存储随附的。
root@ip-10-126-247-82:~# python
Python 2.7.2+ (default, Oct 4 2011, 20:03:08)
[GCC 4.6.1] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import boto.utils
>>> boto.utils.get_instance_metadata()['block-device-mapping']
{'ami': 'sda1', 'root': '/dev/sda1', 'ephemeral0': 'sda2', 'swap': 'sda3'}
这里的映射有点混乱(不知道为什么)。sda -> xvda。从这里你可以看到 / is mapped to /dev/xvda1
,ephemeral0 is mapped to /dev/xvda2
和swap is mapped to /dev/xvda3
。我相信交换空间是由 Xen 管理的,这就是我无法重新格式化/卸载它的原因。
我可以进一步证实这一点
root@ip-10-126-247-82:~# cat /proc/swaps
Filename Type Size Used Priority
/dev/xvda3 partition 917500 0 -1
但现在我不确定交换是否正在被使用,因为它没有出现在mount
输出中。
- 编辑:
关于 EC2 的一般信息,在 c1.medium 上,您可以获得免费交换空间,而在 m1.large 上则没有。我说的“免费”是指您可以卸载它,然后将其回收为另一个临时存储,这只是一个技巧 :)
swapoff -a
mkfs.ext4 /dev/xvda3
mount /dev/xvda3 /mnt
df -h
Filesystem Size Used Avail Use% Mounted on
/dev/xvda1 9.9G 1.6G 7.8G 17% /
udev 849M 4.0K 849M 1% /dev
tmpfs 342M 172K 342M 1% /run
none 5.0M 0 5.0M 0% /run/lock
none 854M 0 854M 0% /run/shm
/dev/xvda3 882M 17M 821M 3% /mnt
答案2
/etc/mtab
通过使用-n
switch in ,可以挂载某些东西而根本不让它出现mount
。
有lsof -n | grep xvda3
返回什么东西吗?