Linux服务器搭建笔记-007:为每位用户创建硬盘配额

2024-03-18 09:36

本文主要是介绍Linux服务器搭建笔记-007:为每位用户创建硬盘配额,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、问题说明

Ubuntu服务器在使用过程中创建的新用户,每位用户会在/home目录下生成一个属于其个人的主文件夹。如果不限制各个用户的使用空间,所有的用户都会共用/home所挂载的硬盘。在这种多用户情况下,会很快的填满/home目录,导致服务器的硬盘空间不够用。

本篇博客通过限制每位用户的硬盘空间,强制培养用户对自己目录的清理习惯。

二、/home目录下每位用户的文件夹空间限制

1. 安装硬盘配额工具

# 安装配额工具
ff@EVA-01:~$ sudo apt-get install quota

2. 编辑启动项以启用配额功能

  • 打开启动项挂载文件
# 修改启动挂载项
ff@EVA-01:~$ sudo vim /etc/fstab
  • 找到/home分区的行,并在挂载选项中添加usrquota和grpquota。例如,如果你的行看起来像这样:
UUID=xxxx-xxxx-xxxx-xxxx /home           ext4    defaults        0       2
  • 修改为:
UUID=xxxx-xxxx-xxxx-xxxx /home    ext4    defaults,usrquota,grpquota        0       2

3. 创建配额数据库和生成配额报告

  • 使用以下命令为/home分区创建配额数据库并生成初始配额报告:
# 创建配额数据
ff@EVA-01:~$ sudo quotacheck -cugm /home
ff@EVA-01:~$ sudo quotacheck -avugm

4. 编辑配额

  • 现在你可以为每个用户设置配额了。使用edquota命令为特定用户编辑配额:
# 为某个用户名文件设定配额
ff@EVA-01:~$ sudo edquota -u username
  • 这会打开nano文本编辑器,显示类似以下内容的配额设置:
Disk quotas for user username (uid 1001):Filesystem        blocks       soft       hard     inodes     soft     hard/dev/sda1           24           0          0         0        0        0
  • 在这里,你需要设置soft和hard限制为指定的KB数,soft配额是警告阈值,而hard配额是绝对限制,用户无法超过这个限制。如果你不希望使用soft配额,可以将其留空或设置为与hard配额相同的值。
  • 在这里,我以150GB限额为例,进行上述文件的修改。因为150GB=150 × \times × 1024 × \times × 1024 = 157286400KB,所以修改为:(注意单位为KB)
Disk quotas for user username (uid 1001):Filesystem        blocks       soft       hard     inodes     soft     hard/dev/sda1           24      157286400  157286400      0        0        0

然后使用ctrl+o进行保存,并按回车,然后按ctrl+x返回。

5. 重复这个过程为每个需要限制的用户设置配额。

  • 更改配额后,使用以下命令检查配额是否正确应用:
# 检查是否应用成功
ff@EVA-01:~$ sudo quota -u username
  • 并且,为了确保配额设置在整个文件系统上生效,你可以再次运行:
ff@EVA-01:~$ sudo quotacheck -avugm
  • 可以使用下面的命令查看所有的配额设置:
ff@EVA-01:~$ sudo repquota -a

(来自一名励志用“普通话”讲技术的菜狗子~)

这篇关于Linux服务器搭建笔记-007:为每位用户创建硬盘配额的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/821930

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Apache Tomcat服务器版本号隐藏的几种方法

《ApacheTomcat服务器版本号隐藏的几种方法》本文主要介绍了ApacheTomcat服务器版本号隐藏的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1. 隐藏HTTP响应头中的Server信息编辑 server.XML 文件2. 修China编程改错误

Linux内核之内核裁剪详解

《Linux内核之内核裁剪详解》Linux内核裁剪是通过移除不必要的功能和模块,调整配置参数来优化内核,以满足特定需求,裁剪的方法包括使用配置选项、模块化设计和优化配置参数,图形裁剪工具如makeme... 目录简介一、 裁剪的原因二、裁剪的方法三、图形裁剪工具四、操作说明五、make menuconfig

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群