文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux入门之磁盘管理(6)磁盘配额

2024-04-02 19:55

关注

Linux入门之磁盘管理(6)磁盘配额

在linux中使用向磁盘中存入数据时,如果有多个用户对同个磁盘进行操作,其中一个用户放了很大数据的文件导致硬盘容量用光,那么其他用户将无法再存入数据,这时就需要对每个用户进行存入数据大小的限制,linux中提供了一种磁盘配额的功能来实现。

 

初始化:

添加分区挂载选项:usrquota、grpquota

初始化数据库:quotacheck 命令

使用命令

开启或取消配额:quotaon、quotaoff

直接编译配额:edquota  [username]

 

案例说明:

创建配额数据库

#/home目录会存放不同用户的文件,大小会相互受影响,因此需要将/home目录变成分区,这里准备好一个创建好文件系统的分区。

[root@mzf ~]# blkid /dev/sda5
/dev/sda5: LABEL="myhome" UUID="97f71277-7b31-4bb6-ae0f-949cf8c18e6f" TYPE="ext4"

#对其进行挂载使用

[root@mzf ~]# mkdir /mnt/myhome
[root@mzf ~]# mount  /dev/sda5  /mnt/myhome/
[root@mzf ~]# df | grep 'myhome'
/dev/sda5             2004852    3096   1896584   1% /mnt/myhome

#先将/home下文件的文件进行迁移

[root@mzf ~]# ls /home/
hadoop  mzf  tom  u1  u2
[root@mzf ~]# mv /home/* /mnt/myhome/
[root@mzf ~]# ls /mnt/myhome/
hadoop  lost+found  mzf  tom  u1  u2

#然后将/dev/sda5再次挂载到/home目录下,并添加用户和组的磁盘配额功能

[root@mzf ~]# mount -L myhome -o usrquota,grpquota /home/
[root@mzf ~]# df | grep 'home'
/dev/sda5             2004852    3288   1896392   1% /mnt/myhome
/dev/sda5             2004852    3288   1896392   1% /home

#卸载掉在/mnt/myhome下的挂载点

[root@mzf ~]# umount /mnt/myhome/

#这里我们再次挂载指定的用户磁盘配额和组磁盘配合选项以及添加

[root@mzf ~]# mount | grep 'home'
/dev/sda5 on /home type ext4 (rw,usrquota,grpquota)

#当然也可以写入/etc/fstab文件进行重新挂载。如,加入内容:

[root@mzf home]# cat /etc/fstab | grep '/home'

Linux入门之磁盘管理(6)磁盘配额 

#然后检查分区并创建配额数据库文件

[root@mzf home]# quotacheck -cgu /dev/sda5
quotacheck: Cannot create new quotafile /home/aquota.user.new: Permission denied
quotacheck: Cannot initialize IO on new quotafile: Permission denied
quotacheck: Cannot create new quotafile /home/aquota.group.new: Permission denied
quotacheck: Cannot initialize IO on new quotafile: Permission denied

解析:这里提示没有权限,可能是linux内核中默认开启的selinux安全机制控制导致的,这里我们可以先将其关闭:

#查看当前setlinux是否开启

[root@mzf home]# getenforce
Enforcing#表示已经启用
[root@mzf home]# setenforce 0          #设置参数为0表示禁用
[root@mzf home]# getenforce          #再次查看已经显示为禁用
Permissive

#再次进行磁盘配额数据库文件创建

[root@mzf home]# quotacheck -cug /dev/sda5

#查看指定分区单独挂载点目录下是否生成了磁盘配额数据库文件

[root@mzf home]# ls /home  | grep '^aquota\.\<\(user\|group\)\>' 
aquota.group
aquota.user

说明:如果要开启磁盘配额,内核模块必须检查该挂载点中是否有磁盘配额数据库文件的存在,否则无法开启或设置成功。

 

启用磁盘配额:

#开启指定分区的磁盘配额

[root@mzf home]# quotaon /dev/sda5

#添加默认磁盘配额成员

[root@mzf home]# edquota -p mzf tom hadoop

#设置指定成员配额

[root@mzf home]# edquota hadoop

#进入vim编辑界面

Linux入门之磁盘管理(6)磁盘配额 

解析:其中第一行表示为哪个用户设置磁盘配额,下面分为多列,第一列为指定的文件系统,后面6列每3列为一组,blocks表示已经存放的文件大小,默认为k,indodes表示为已经创建了多少个文件,soft表示为软限制,存放大小超过soft指定将出现警报,hard为硬限制,如果达到此限制,将无法再次写入数据。


#按文件所占大小设置配额,软限制为5M,硬限制为10M

Linux入门之磁盘管理(6)磁盘配额 

#切换到设置配额的成员hadoop用户

[root@mzf home]# su - hadoop

#此目录已经用了64K,这里我们添加 5M数据

[hadoop@mzf ~]$ dd if=/dev/zero of=/home/hadoop/temp.log bs=5M  count=1
sda5: warning, user block quota exceeded.
1+0 records in
1+0 records out
5242880 bytes (5.2 MB) copied, 0.130323 s, 40.2 MB/s

注意:这里soft已经超过,开始了警报,显示用户块数据配额,但是如果使用echo进行一些小规模数据追加,磁盘配额是不会警报的:

#显示出文件多少个字节

[hadoop@mzf ~]$ ls -l /home/hadoop/temp.log 
-rw-rw-r--. 1 hadoop hadoop 5242912 Aug 17 23:51 /home/hadoop/temp.log

#追加字节

[hadoop@mzf ~]$ echo "***************" >> /home/hadoop/temp.log

#再次显示大小已经增加,但是磁盘配额没有警报

[hadoop@mzf ~]$ ls -l /home/hadoop/temp.log 
-rw-rw-r--. 1 hadoop hadoop 5242928 Aug 17 23:51 /home/hadoop/temp.log

解析:如果再用dd命令对temp.log文件写入5M是无法写入的,那么再写一个5M的新文件进行测试:

#再创建一个5M,那么应该已经达到了10M

[hadoop@mzf ~]$ dd if=/dev/zero of=/home/hadoop/temp2.log bs=5M  count=1
sda5: write failed, user block limit reached.
dd: writing `/home/hadoop/temp2.log': Disk quota exceeded
1+0 records in
0+0 records out
5185536 bytes (5.2 MB) copied, 0.00903 s, 574 MB/s

解析:这里已经显示了写入数据错误,数据块配额已经被使用完

#这时写入一个字节内容的文件都写入不了了。

[hadoop@mzf ~]$ echo "1" > file1
-bash: echo: write error: Disk quota exceeded

 

其它磁盘配额管理工具

quota   查看配额信息

[root@mzf home]# quota hadoop
Disk quotas for user hadoop (uid 502): 
    Filesystem  blocks  quota  limit  grace  files  quota  limit  grace
   /dev/sda5   10240*  5120   10240  6days   17   0    0

解析:grace表示为宽限期,及文件大小到到soft指定大小6天后,soft将变成硬限制,将再也无法创建文件和写入数据了。

requota  #查看指定信息

warnquota  #检查警告

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯