WatchStor.com — 领先的中文存储网络媒体 | 51CTO旗下网站

评测导购 > FC SAN > 正文

深入分析Linux文件管理系统

Watchstor.com  佚名丨2009-10-29 11:09 标签:FC SAN Linux 

系统Linux正在被大多数的研发者和企业所接受,经过长时间学习Linux,于是和大家分享一下,看完本文你肯定有不少收获,希望本文能教会你更多东西。

1.软盘

如同硬盘,一张软盘也分为磁道和扇区(软盘两面上的相同的磁道组成柱面),但数量要比硬盘少得多。

软驱通常可以使用几种不同的软盘,例如,一个3.5英寸软驱可以使用720KB和1.44MB的软盘。因为软驱操作有些不同,而操作系统必须知道软盘的容量,所以软驱有许多设备文件,每个都与软驱和软盘种类有关。因此,/dev/fd0H1440 是第一个软驱(fd0),必须是3.5英寸,使用3.5英寸高密度软盘(H),容量是1440KB(1440),即普通的3.5英寸HD软盘。

软驱的名字是复杂的,因此Linux有一个特定的软驱设备类型,能自动检测软驱中软盘的种类。它使用不同的软盘类型,试图读取新插入的软盘的第一个扇区,直到找到正确的一个。这自然要求软盘是已经格式化过的。

Linux除了能处理所有标准的软盘,还能处理许多非标准的软盘格式。这有时需要特殊的格式化程序。我们现在先跳过这些软盘格式,同时你可以查看/etc/fdprm文件,它定义了setfdprm 识别的设置。

2.格式化软盘

软盘格式化使用fdformat命令。软盘设备使用给定的参数,例如下面的命令是在第一个软驱中格式化一张高密度3.5英寸软盘:

$ fdformat /dev/fd0H1440

Double-sided, 80 tracks, 18 sec/track. Total capacity 1440 kB.

Formatting ... done

Verifying ... done

$

注意,如果想使用自动检测设备(如/dev/fd0),必须先用setfdprm 设置参数。要得到与上面一样的结果,可以这样:

$ setfdprm /dev/fd0 1440/1440

$ fdformat /dev/fd0

Double-sided, 80 tracks, 18 sec/track. Total capacity 1440 kB.

Formatting ... done

Verifying ... done

$

选择与软盘类型相符的正确的设备文件通常更方便。注意,比软盘设计格式化更多的信息容量是没有意义的。

3.CD-ROM

CD-ROM 驱动器使用一个光学可读的塑胶涂布的碟片。信息记录在盘表面的从中心到边沿的螺旋型小坑上。 驱动器发出一束激光来读盘。当激光射到小坑上,激光以一种方式反射;当它射到光滑表面上,它以另一种方式反射。这很容易地编码成bit,组成信息。

CD-ROM驱动器比硬盘慢。典型的硬盘的平均寻道(seek)时间小于15ms,而快速的CD-ROM驱动器要花零点几秒。实际资料传输率则相当快,在数百KB/s。速度慢使CD-ROM驱动器不能代替硬盘使用(有些Linux distributions提供“live”CD-ROM文件系统,使之不必复制文件到硬盘,使安装简单并节约了许多硬盘空间),虽然是可能的。要安装新软件,CD-ROM很好用,因为在安装时速度并非最重要的。

不同UNIX不能使用ISO9660文件系统,因此开发了对这个标准的一个增强,叫Rock Ridge增强。Rock Ridge允许长文件名、符号连接和许多其他优点,使CD-ROM更像UNIX文件系统。同时,Rock Ridge文件系统仍然是一个有效的ISO9660文件系统,使非UNIX用户一样可以使用。Linux同时支持ISO9660和Rock Ridge增强,增强被自动识别和使用。

文件系统只是一部分,许多CD-ROM包含的资料需要特定的程序存取,而多数程序不能运行在Linux下(当然,可能运行在Linux的MS-DOS模拟器dosemu下)。

管理用户的磁盘空间

1.为普通用户和用户组加入磁盘配额限制

Linux文件管理系统的Quota程序允许为系统上每一用户或用户组指定所能使用的磁盘配额。目前Quota仅能工作在ext2和ext3类型的Linux文件管理系统上。使用Quota需要确定以下两点:

(1)当前的系统内核支持Quota。

(2)系统已正确安装Quota套装程序。

如果你当前的系统内核不支持Quota,请重新编译你的内核,当系统提示:

Quota support(CONFIG—QUOTA)[n]

回答y,生成新的系统内核。

如果没有Quota套装程序,请到以下地址下载Quota的源程序并编译:

ftp://ftp.funet.fi/pub/l inux/PEOPLE/Linus/subsystems/Quota/all.tar.gz

一般Linux的发行版本的内核都默认包含了Quota支持,也附带了Quota 套装程序,只需安装Quota 并加以设置便可让Quota工作。

Quota的具体设置步骤:

(1)编辑系统初始脚本让它检查Quota并启动。

# Check Quota and then turn Quota on.

if [ -x /usr/sbin/Quotacheck ]

then

echo ″Checking Quotas. This may take some time.″

/usr/sbin/Quotacheck -avug

echo ″Done.″

fi

if [ -x /usr/sbin/Quotaon ]

then

  echo ″Turning on Quota.″

  /usr/sbin/Quotaon -avug

fi

(2)编辑/etc/fstab。你的 /etc/fstab文件可能会是如下的形式:

/dev/hda1 / ext2 defaults 1 1

/dev/hda2 /home ext2 defaults 1 1

选择用户所在分区的行的第4个域,为用户加入Quota支持,如下:

/dev/hda1 / ext2 defaults 1 1

/dev/hda2 /home ext2 defaults,usrQuota 1 1

如为用户组加入Quota支持,可将usrQuota替换为grpQuota。

如两者兼而有之,可将这两项一并写入,如下:

/dev/hda1 / ext2 defaults 1 1

/dev/hda2 /home ext2 defaults,usrQuota,grpQuota 1 1

(3)创建Quota记录文件Quota.user和Quota.group。进入用户所在分区根目录,如在上例中输入cd /home即可,按下面命令创建文件:

touch Quota.user

touch Quota.group

chmod 600 Quota.user Quota.group

完成上面几步以后,重新启动电脑以使设置生效。

(4)为用户或用户组设置磁盘配额限制。假设在你的系统上有一名为bob 的用户,现在想给他10MB的硬盘配额限制,他所拥有的最大文件数不得超过100个。执行edQuota -u dquo,系统将进入编辑环境(具体编辑环境视editor变量设置而定),将如下3行

Quotas for user bob:

/dev/hda2: blocks in use: 14, limits (soft=0, hard=0)

inodes in use: 12, limits (soft=0, hard=0)

改为

Quotas for user bob:

/dev/hda2: blocks in use: 14, limits (soft=0, hard=10240)

inodes in use: 12, limits (soft=0, hard=100)

其中,

blocks in use:用户已使用块的大小,单位是KB。

inodes in use:用户现有文件的大小。

这两项都是系统自动给出的,不必改动。

2.软限制(soft limits)

通常设置软限制为一个接近硬限制的值,超越此限制时,Linux文件管理系统将警告用户将到达最大磁盘配额限制。软限制为0 时没有软限制。结合宽限期使用时,只要用户超越了软限制,一过宽限期,任何对磁盘空间的额外需求将被立即拒绝。

3.硬限制(hard limits)

硬限制磁盘配额的绝对限制,设置了Quota的用户不能超越此限制。

4.宽限期(Grace Period)

宽限期是用户超越了软限制而没有到达硬限制时的一段放宽期,在这段时间内,用户可以在硬限制范围内自由地使用磁盘空间,超过这段时间,所有对磁盘空间的额外需求将被拒绝,即使用户还在硬限制之内。宽限期的单位可以是秒、分、时、天。执行edQuota -t命令可设置宽限期。执行该命令后,将系统提示中的两个0 days 改成你认为合适的值即可。

有时想给一批用户加上同样的限制,比如,给系统上所有100个用户加上与bob同样的限制,可手工先给bob加上限制,然后执行下面命令:

edQuota -p bob ′awk -F: ′$3 499 {print $1}′/etc/passwd′

给用户组设置磁盘配额限制与普通用户类似,假设有一用户组game,执行edQuota -g game即可。

5.控制用户的登录地点

文件/etc/secruity/access.conf可控制用户登录地点,为了使用access.conf,必须在文件/etc/pam.d/login中加入下面的行:

account required /lib/security/pam-access.so

access.conf文件的格式:

permission : users : origins

其中,

permission:可以是+或-,表示允许或拒绝。

user:可以是用户名、用户组名,如果是all则表示所有用户 。

origins:登录地点。local表示本地,all表示所有地点,console表示控制台。另外,origins也可以是某一个网络。

后面两个域中加上 except是“除了”的意思。例如,除了用户 wheel, shutdown, sync禁止所有的控制台登录:

-:ALL EXCEPT wheel shutdown sync:console

root账户的登录地点不在access.conf文件中控制,而是由/etc/securetty文件控制。

6.限制用户每次所发邮件大小

Linux文件管理系统使用sendmail发送邮件,配置文件是/etc/sendmail.cf,默认使用TCP/IP协定。我们的Linux机器上往往会有多个用户同时工作,或者干脆就用它作为邮件服务器,在同一时刻,系统可能要收发很多邮件,因此不能让某一用户过多地占用sendmail的时间。sendmail的默认配置对每次收发邮件的大小没有限制,更改配置文件/etc/sendmail.cf,找到O MaxMessageSize,去掉行首的#号,并将其后的数值改为合适的数值,单位为字节。如:

O MaxMessageSize = 1048576

意思为每次收发邮件最大为1MB,任何超过这个值的邮件将被拒绝。

【编辑推荐】

  1. 文件系统在不同需求下的不同选择
  2. 根文件系统菜鸟大扫盲
  3. NAS存储系统分析核心文件系统WAFL
  4. Nutch分布式文件系统:解决网络文件存储管理
  5. 基于PVFS(并行虚拟文件系统)的并行网络存储系统

    相关资讯

    今日微信独家

    《华尔街日报》报道日前援引知情人士的消息称,由于被美国政府以国家安全问题为由进行调查,联想斥资23亿美元收购IBM低端服务器业务的交易陷入了停滞状态。
    关注新浪官博 订阅微信订阅号

    订阅焦点周刊

    论坛与活动

    2016中国数据加速峰会直播专题
    2016中国数据加速峰会直播专题[详细]
    点击查看

    精彩视频

    最新文章

    1111111
    1111111
    asdasd
    asdasd
    同有科技应用型大数据存储在南京掀起智能风暴
    同有科技应用型大数据存储在南京掀起智能风暴
    斯蒂芬斯蒂芬
    斯蒂芬斯蒂芬
    京东双11技术备战 构建多中心交易系统
    京东双11技术备战 构建多中心交易系统