设为首页 收藏本站
查看: 317|回复: 0

[经验分享] 利用quota对Vsftpd做磁盘配额

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-5-18 13:21:12 | 显示全部楼层 |阅读模式
1 增加一块2G的硬盘
打开VMware点击VM---settings—add—Hard Disk—---Create a new virtual disk—SCSI—disk size(GB)2.0----重启虚拟机系统
2 验证硬盘:
[iyunv@viong ~]# fdisk -l      
1
2
3
4
#已增加了2G的/dev/sdb
Disk /dev/sdb: 2147 MB, 2147483648 bytes  -----------à说明已经生效了
255 heads, 63 sectors/track, 261 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes



3 先把/dev/sdb划分为一个扩展分区,再新建一个逻辑分区,格式化为ext3分区,然后设置为重启自动加载。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
[iyunv@viong ~]# fdisk /dev/sdb
#对/dev/sdb进行分区
Device contains neither a valid DOS partition table, nor Sun, SGI or OSF disklabel
Building a new DOS disklabel. Changes will remain in memory only,
until you decide to write them. After that, of course, the previous
content won't be recoverable.
Warning: invalid flag 0x0000 of partition table 4 will be corrected by w(rite)
Command (m for help): n  #增加一个分区
Command action
e   extended
p   primary partition (1-4)
#e增加扩展分区
Partition number (1-4): 1
First cylinder (1-261, default 1): 回车
Using default value 1
Last cylinder or +size or +sizeM or +sizeK (1-261, default 261): 回车
Using default value 261
Command (m for help): w   #保存退出
The partition table has been altered!
Calling ioctl() to re-read partition table.
Syncing disks.
[iyunv@viong ~]# fdisk /dev/sdb
Command (m for help): n
Command action
l   logical (5 or over)
p   primary partition (1-4)
#l增加逻辑分区
First cylinder (1-261, default 1): 回车
Using default value 1
Last cylinder or +size or +sizeM or +sizeK (1-261, default 261): 回车
Using default value 261
Command (m for help): w
The partition table has been altered!
Calling ioctl() to re-read partition table.
Syncing disks.



4 验证/dev/sdb的分区情况
1
2
3
4
5
6
Disk /dev/sdb: 2147 MB, 2147483648 bytes
255 heads, 63 sectors/track, 261 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot      Start         End      Blocks   Id  System
/dev/sdb1               1         261     2096451    5  Extended
/dev/sdb5               1         261     2096419+  83  Linux



5 格式化 /dev/sdb5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[iyunv@viong ~]# mkfs.ext3 /dev/sdb5  格式化sdb5
mke2fs 1.39 (29-May-2006)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
262144 inodes, 524104 blocks
26205 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=536870912
16 block groups
32768 blocks per group, 32768 fragments per group
16384 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912
Writing inode tables: done                           
Creating journal (8192 blocks): done
Writing superblocks and filesystem accounting information: done
This filesystem will be automatically checked every 25 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.



6 创建一个目录来挂载sdb5
1
2
3
4
5
6
[iyunv@viong ~]# mkdir /mnt/ftp
[iyunv@viong ~]# mount /dev/sdb5 /mnt/ftp/
挂载sdb5到/mnt/ftp/
[iyunv@viong ~]# vi /etc/fstab  
添加最后一条信息,来达到重启自动挂载上去
/dev/sdb5    /mnt/ftp         ext3 defaults          0 0



7 #mount -a  最后重启系统看有没有被自动挂载上
8 创建一个ftp用户做测试
1
2
3
4
5
6
7
8
9
10
[iyunv@red-hat-5 ~]# useradd -d /mnt/ftp/hom -s /sbin/nologin hom
[iyunv@red-hat-5 ~]# passwd hom
Changing password for user hom.
New UNIX password:
Retype new UNIX password:
passwd: all authentication tokens updated successfully.
[iyunv@red-hat-5 ~]# ll /mnt/ftp/
总计 20
drwx------ 2 hom  hom   4096 01-10 17:15 hom
drwx------ 2 root root 16384 01-10 16:53 lost+found



1
2
[iyunv@red-hat-5 ~]# service vsftpd start
为 vsftpd 启动 vsftpd:[确定]



9 为ftp用户做磁盘配额
刚才创建的hom用户是在/dev/sdb5分区中,那么如果我们要对hom用户进行磁盘限额,那我们需要修改/etc/fstab中根分区的记录,将/dev/sdb5分区的第4个字段改成defaults,usrquota,如下:
1
/dev/sdb5    /mnt/ftp   ext3   defaults,usrquota          0 0



为了不然系统重启才生效,利用一下命令直接生效
1
# mount -o remount /dev/sdb5



10 对一个组进行磁配额,那我们需要增加参数grpquota,如下:
1
/dev/sdb5   /mnt/ftp    ext3    defaults,usrquota, grpquota      0  0




11 生成每个启动了配额的文件系统的当前磁盘用量表
1
2
3
4
5
6
root@viong /]# quotacheck -avug
quotacheck: Scanning /dev/sdb5 [/mnt/ftp] quotacheck: Cannot stat old user quota file: 没有那个文件或目录
quotacheck: Old group file not found. Usage will not be substracted.
done
quotacheck: Checked 4 directories and 6 files
quotacheck: Old file not found.



注释:
-a   :扫瞄所有在 /etc/mtab 里头已经 mount 的具有 quota 支持的磁盘
-u  :扫瞄使用者的档案与目录
-v  :显示扫瞄过程
-g  :扫瞄群组使用的档案与目录
-m :强制进行 quotacheck

12 设置限额容量
1
[iyunv@viong /]# edquota -u hom   (设置限额容量)



为用户hom设置磁盘配额
系统会自动用
VI文本打开配额文件,如下:
1
2
3
Disk quotas for user hom (uid 501):
Filesystem   blocks    soft      hard     inodes     soft     hard
/dev/sdb5    16      0         1024      4       0        0




这里为了做测试,我把硬块限度为1024kb

注释:
Filesystem是启用了配额的文件系统的名称
blocks显示了用户当前使用的块数,单位为KB
soft用来设置用户在该文件系统上的软块限度.使用者在宽限期间之内,他的容量可以超过 soft ,但必需要宽限时间之内将磁盘容量降低到 soft 的容量限制之下
hard用来设置用户在该文件系统上的硬块限度,绝对不能超过的容量
inodes显示了用户当前使用的i节点数量。
最后两列用来设置用户在该文件系统上的软硬i节点限度.不同的是软限可以在一段时期内被超过。 soft 到 hard 之间的容量其实就是宽限的容量啦!可以达到针对使用者的警示作用!这段时期被称为过渡期(grace period),默认七天的超越。过渡期可以用秒钟、分钟、小时、天数、周数、或月数表示。
如果以上值中的任何一个被设置为 0,那个限度就不会被设置。
注释:
-u  :编辑 user 的 quota
-g  :编辑 group 的 quota
-t  :编辑宽限时间(就是超过 quota 值后,还能使用硬盘的宽限期限)
-p  :copy 模板(以建立好的使用者或群组)到另一个使用者(或群组)

13 打开磁盘配额监控进程
1
root@viong /]# quotaon  -avu



  u是用户g是组,这里我没设置g参数
/dev/sdb5 [/mnt/ftp]: user quotas turned on
注释:
-a  :全部的 quota 设定都启动(会自动去寻找 /etc/mtab 的设定)
-u  :使用者的 quota 启动
-g  :群组的 quota 设定启动
-v  :显示讯息  

14 要校验用户的配额是否被设置
1
2
3
[iyunv@viong /]# quota -uvs hom
Filesystem  blocks   quota   limit   grace   files   quota   limit   grace
/dev/sdb5   16       0    1024               4       0       0




注释:
-g  :显示 group 群组
-u  :显示 user
-v  :显示 quota 的值
-s  :选择 inod 或 硬盘空间来显示

15 设置过渡期(grace period),只针对软限制而言
1
2
3
4
5
[iyunv@viong /]# edquota –t
Grace period before enforcing soft limits for users:
Time units may be: days, hours, minutes, or seconds
Filesystem             Block grace period     Inode grace period
/dev/sdb5                7days                  7days



16 查看用户配额
1
2
3
4
5
6
7
*** Report for user quotas on device /dev/sdb5
Block grace time: 7days; Inode grace time: 7days
Block limits                File limits
User            used    soft    hard  grace    used  soft  hard  grace
----------------------------------------------------------------------
root      --    35880    0       0             5     0     0      
hom       --    16      0      1024            4     0     0





注释:
-a   列出在/etc/fstab文件里,有加入quota设置的分区的使用状况与用户和群组
-g   列出所有群组的磁盘空间限制
-u   列出所有用户的磁盘空间限制
-v   显示该用户或群组的所有空间限制


17 测试用户配额是否生效

下面利用FlashXP做测试,上传一首故乡原风景.mp3,传输到1M就失败了.说明生效了

1
[iyunv@viong /]# quotaoff  -vug /dev/sdb5



关闭/mnt/ftp分区的磁盘限额
1
/dev/sdb5 [/mnt/ftp]: user quotas turned off




注释:
-a  :全部的 quota 设定都关闭(会自动去寻找 /etc/mtab 的设定)

最后并删除/etc/fstab中设置配额的部分


总结:在对用户进行磁盘限额时,需要掌握以下几点原则:
A.由于对用户进行文件数量的限制不是很实用,所以通常进行磁盘配额只限制用户占用的磁盘容量。
B.为用户设置的软限制和硬限制的数值都不应该小于用户已占用的磁盘容量或文件数量,否则可能造成用户无法正常登录和使用系统。
C.设置的硬限制数量应该大于软限制数量,否则没有实际的意义
D././boot/./proc./mnt/cdrom 等不要使用配额
E.quota 实际在运作的时候,是针对整个分区进行限制的,例如:如果你的 /dev/sdb5 是挂载在/mnt/ftp底下,那么在 /mnt/ftp底下的所有目录都会受到限制!


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-68128-1-1.html 上篇帖子: Linux中jobs的管理常用命令 下篇帖子: Kickstart 安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表