关于RedHat7.3如何做系统用户配额的方法(原创)

由 linuxsky 在 05-20-2002 16:17 发表:

关于RedHat7.3如何做系统用户配额的方法(原创)

我的过程

装系统时分一个/home分区

同时我还分了一个/www分区

一个用来做文件服务(smb)--内网

另一个/www打算将来做ftp web之类的服务--外网

装完后

修改/etc/fstab

(改之前最好把这个文件cp一份到其它地方,以防改错后可以复原)

这是我改好的fstab文件

LABEL=/ / ext3 defaults 1 1

LABEL=/boot /boot ext3 defaults 1 2

none /dev/pts devpts gid=5,mode=620 0 0

LABEL=/home /home ext3 defaults,usrquota 1 2

none /proc proc defaults 0 0

none /dev/shm tmpfs defaults 0 0

LABEL=/www /www ext3 defaults,usrquota 1 2

/dev/hda9 swap swap defaults 0 0

/dev/cdrom /mnt/cdrom iso9660 noauto,owner,kudzu,ro 0 0

/dev/cdrom1 /mnt/cdrom1 iso9660 noauto,owner,kudzu,ro 0 0

/dev/fd0 /mnt/floppy auto noauto,owner,kudzu 0 0

我在第四行和第七行的defaults后加了 ,usrquota进去

然后存盘出来

再接着我修改/etc/rc.d/rc.local脚本,添加如下脚本:

#############################

#check quota and turn quota on

if [-x /sbin/quotacheck ];then

echo "Checking quotas,This may take some time ... "

/sbin/quotacheck -avug

echo "Done."

fi

if[ -x /sbin/quotaon ];then

echo "Enabling disk quota ... "

/sbin/quotaon -avug

echo "Done."

fi

#############################

这一段脚本在装载完文件系统后运行,它将对磁盘配额的情况进行检查并激活磁盘配额功能。

然后要为每一个实行配额控制的分区创建配额文件。

输入以下命令

touch /home/aquota.user

touch /www/aquota.user

用chmod修改这两个文件的许可属性,使它只对root用户有读和写的许可

重新启动系统。

这样系统在运行配额检查的时候,会在配额文件中创建磁盘使用信息。到这里,我们已经完成磁盘配额所需要的系统级的支持配置。接着

,我们就可以将配额分配给用户了。

重启完成后

可用webmin来管理配额.很方便的.

看我的图

http://www.szsy.net/zzm/jpg/2.jpg

http://www.szsy.net/zzm/jpg/3.jpg


由 linuxsky 在 05-20-2002 16:17 发表:


另附上网上找到的字符界面下的管理配额的方法

设置用户和组配额的分配量

对磁盘配额的限制一般是从一个用户占用磁盘大小和所有文件的数量两个方面来进行的。在具体操作之前,我们先了解一下磁盘配额的两

个基本概念:软限制和硬限制。

软限制:一个用户在文件系统可拥有的最大磁盘空间和最多文件数量,在某个宽限期内可以暂时超过这个限制。

硬限制:一个用户可拥有的磁盘空间或文件的绝对数量,绝对不允许超过这个限制。

◆使用编辑配额命令edquota为用户配置定额

在重新启动系统之后,我们假设lanf是需要定额的系统帐户,可以使用如下命令来为用户分配磁盘配额:

edquota -u lanf

这个命令将启动默认文本编辑器(如vi或其他由$EDITOR 环境变量指定的编辑器),其内容如下所示:

Quotas for user lanf:

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

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

这表示lanf用户在/dev/sda5分区(该分区已经在usrquota的控制之下)中迄今使用了0个数据块(以K为单位),并且没有设限制(包括软

限制soft和硬限制hard),同样,lanf在这个分区也没有任何文件和目录,并且也没有任何软硬限制。

如果,我们想对用户进行磁盘容量的限制的话,只需要修改blocks行的limits部分就可以了,注意单位使用的是K。例如要为lanf分配100M

磁盘的软限制,400M硬限制,可以使用如下的设置:

Quotas for user lanf:

/dev/sda5:blocks in use:0,limits(soft = 102400,hard = 409800)

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

同样的,要对文件目录的数量限制可以相应的修改inodes行。我们也可以同时对这两项都作出限制。只需要如下的修改

Quotas for user lanf:

/dev/sda5:blocks in use:0,limits(soft = 102400,hard = 409800)

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

这表示除了相应的容量的限制外,还对文件/目录的数量做了12800个的软限制和51200个的硬限制。在保存了新的配置后,该用户的磁盘使

用就不能超过硬限制。如果用户试图超过这个限制,该操作将被取消,然后得到一个错误信息。

但是,如果每个用户都要这么麻烦的设置的话,那这种重复的体力劳动实在有点令人不寒而栗,而且也太浪费时间了。幸好edquota还有个

-q参数(prototype)可以对已有的用户设置进行拷贝。例如,我们想对Jack、Tom、Chen三个用户使用和lanf一样的限额配置,可以使用如下

的命令:

edquota -p lanf -u Jack Tom Chen

这样一来,这三个用户就被赋予了和lanf一样的磁盘配额。

对组的配额,除了edquota命令中对应-u参数的改为-g参数,例如下面对webterm1组的操作:

edquota -g webterm1

实际上,以上的限制只是对用户设定的硬限制在起作用。如果需要使软限制也起作用的话,还需要对用户的软限制设定宽限期——缺省的

,软限制的宽限期是无穷大——这可以使用edquota命令的-t选项来实现。运行下面的命令:

edquota -t

edquota将打开缺省编辑器显示如下内容:

Time units may be:days,hours,minutes,or seconds

Grace period before enforcing soft limits for users:

/dev/sda5:block grace period:0 days,file grace period:0 days

可以使用天、小时、分、秒为单位来设定宽限期。例如,在下面这个例子中,磁盘空间限制的宽限期为两天,而文件数量限制的宽限期只

有6个小时。

Time units may be:days,hours,minutes,or seconds

Grace period before enforcing soft limits for users:

/dev/sda5:block grace period:2 days,file grace period:6 hours

◆查看用户磁盘使用情况

要查明某一个用户使用了多少磁盘空间,例如lanf,可以使用如下的命令:

quota -u lanf

显示:

Disk quotas for user lanf(uid 503):

Filesystem blocks quota limit grace file quota limit grace

/dev/sda5 3 102400 409800 1 12800 51200

同样,可以使用quota -g groupname命令来参看某个组的磁盘使用情况。

注意: 1、如果该用户没有配置磁盘限额的话,输出显示如下:

Disk quotas for user hujm (uid 503): none

2、如果不带任何参数运行quota的话,查看的是你自己的配额使用情况。


由 linuxsky 在 05-20-2002 16:22 发表:


注意

上面加到rc.local里的那段脚本有个/sbin/quotacheck是指的这个命令的路径,如果不在这个目录下,请用rpm -ql quota

来确定目录..


由 pandonny 在 05-20-2002 16:38 发表:


Linuxsky兄弟经过实战的经验总结,有这方面需要的兄弟们的必备参考指南


关爱社区,共建家园!


由 linuxsky 在 05-22-2002 07:36 发表:


今天有网友发邮件给我

提到quota.user的问题

我想提示一点的是

如果你用的是redhat的7.x版

一定要用touch /dir/aquota.user

而不是quota.user

不然就会提示出错的.

我原先刚试的时候参考网上的教程也是这样.用的quota.user

一直无法成功..直到后来看了一些文档才明白.


由 ryhbgs 在 04-11-2003 09:24 发表:


可我总是显示:

[test@home test]# convertquota -u /home

convertquota: Quota file not found or has wrong format.

convertquota: Can't open old format file for users on /home

附:

[test@home test]# more /etc/fstab

LABEL=/ / ext3 defaults 1 1

LABEL=/boot /boot ext3 defaults 1 2

LABEL=/mailbox /data ext3 defaults 1 2

non

Published At
Categories with 服务器类
Tagged with
comments powered by Disqus