mount(手工挂载/自动挂载)问题小结

2009-05-13 08:46:20来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

mount(手工挂载/自动挂载)问题小结


1.vfat文件编码方式
fat32文件名分为两种,短文件名和长文件名
两种文件名在磁盘上的存储方式是不同的,长文件名在目录项中特殊的标记
短文件名也就是8.3格式,对于包含中文的任何文件来说都不可能是短文件名
mount挂载时默认将其变成小写,你可以加-o shortname=winnt来使其和
win2k/xp一致
长文件名都是unicode的,以utf16格式存储
2.codepage与iocharset
对于挂载fat32磁盘来说,codepage不需要设置,因为它只对短文件名编码方式起作用
系统默认cp437就足够了
unix世界里很多程序都不处理utf16,iocharset将16位unicode字符转成其他字符集,
系统默认为iso8859-1,一般把它设置成linux系统使用的字符集,如cp936(GBK),utf8
(注:不过linux系统推荐不要使用iocharset选项,推荐直接使用-o utf8 或者utf8=true
具体可参见linux-2.6.19/Documentation/filesystems/vfat.txt原文)
3.一般手工挂载/卸载步驟
(假定为root或sudo进行操作的用户,关于其他用户的挂载见后面)
*找到需要挂载的设备名,通过查看所有块设备:
cat /proc/partitions 或 fdisk -l
如果还是不清楚,可以对比查看已挂载设备:
mount 或 mount -l (-l选项会多输出卷标)
或cat /proc/mounts
cat /etc/mtab (加-n选项mount的设备不显示)
*找到设备后,选择一个空目录作为挂载点
(当然你也可以把一个非空目录作为挂载点,但那样很容易将目录中的文件内容搞混)
如挂载u盘/dev/sda1到/mnt下,系统字符设定为utf8
mount -t vfat /dev/hda /mnt -o utf8
就足够了
不加-t vfat在很多情况下也是可以的,但手册上建议最好指定,因为不加-t的话,mount
会先去读根据/etc/filesystems,/proc/filesystems中的文件系统类型进行猜测,只是
一种启发式的猜测(与幻数magic有关),可能会出现问题
如果需要其它选项,见mount(8)
*卸载设备
确保当前目录不在挂载目录中,并关闭所有使用挂载目录中文件的程序
umount 或
如果输出还是device busy,可以使用
fuser
查看哪个进程号正在使用该设备,结合ps aux应该能解决问题
(注:-f虽然是强制卸载的含义,但只是针对nfs设计的)
4.固定设备最好在/etc/fstab中设定
     
对于最后一项,如果/根分区要检查设为1,ext2/3最好设成1
其它文件系统要检查的话需设成2,对于fat32,ntfs文件系统个人觉得没有必要
例如:
#      
none /dev/pts devpts defaults 0 0
none /dev/shm tmpfs defaults 0 0
/dev/hda7 swap swap defaults 0 0
/dev/hda8 / ext3 defaults 0 1
/dev/hda1 /media/winc vfat ro,uid=1000,utf8 0 0
/dev/hda5 /media/wind vfat rw,uid=1000,utf8 0 0
/dev/hda6 /media/wine vfat rw,uid=1000,utf8 0 0
/dev/sda1 /media/sda1 vfat rw,user,utf8,noauto 0 0
系统在init加载完驱动模块后,会用一个类似mount -a的命令对/etc/fstab中的设备进行加载,
因此,有些人觉得没有必要每次都挂载那些fat32盘,只要在/etc/fstab选项中加上noautoid
就可以了,cdrom(/dev/hdc或/dev/cdrom)也可以加上noauto放在这里
登录进去之后如果想要挂载,mount 设备名或挂载点 就好了
注:user选项的意思可以让任何人都mount该设备,不过如果其他人或系统已经将其mount上了,
其余非root用户就不能umount; 要想让任何人都可以umount该设备,将user选项改成users

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Linux HAL (Hardware Abstraction Layer)的工作原理

下一篇:${ }的用法