简单的说就是限制用户对磁盘空间的使用量。
因为Linux是多用户多任务的操作系统,许多人共用磁盘空间,为了合理的分配磁盘空间,于是就有了quota的出现。
显示磁盘使用情况和配额
(1)针对WWW server
(2)针对mail server
(3)针对file server
(1)仅能针对整个文件系统
(2)需要kernel的支持
(3)只对一般用户有效
测试环境
RHEL6.6(默认kernel已经支持quota功能)
/dev/sdb1 供测试的文件系统
用户组 myquota
用户 quota1,quota2
具体操作如下
(1)重新挂/dev/sdb1文件系统,并添加usrquota,grpquota参数
[root@localhost ~]# mount -o remount,usrquota,grpquota /dev/sdb1
重新挂载后,/dev/sdb1这个分区就支持quota功能了
[root@localhost ~]# mount | grep /dev/sdb1
/dev/sdb1 on /mnt/test type ext4 (rw,usrquota,grpquota)
(2)添加用户组和用户
[root@localhost ~]# groupadd myquota
[root@localhost ~]# useradd -g myquota quota1
[root@localhost ~]# useradd -g myquota quota2
(3)生成quota配置文件
[root@localhost ~]# cd /mnt/test/
[root@localhost test]# quotacheck -ug .
[root@localhost test]# ls
aquota.group aquota.user lost+found 生成quota配置文件
(4)启动quota功能
[root@localhost test]# quotaon /dev/sdb1
若要关闭 使用quotaoff命令
(5)修改quota配置文件
配置文件内容如下
Filesystem blocks soft hard inodes soft hard
/dev/sdb1 0 0 0 0 0 0
需要修改的是soft/hard的值,单位是KB,soft为警告值,hard为最大值,当磁盘使用量在soft-hard之间,就会发出警告(默认倒计时7天),若超过警告时间,磁盘使用量依然在soft-hard 之间,则会禁止使用磁盘空间。
若修改blocks的soft/hard表示规定用户可以使用的磁盘空间大小(一般都是规定磁盘使用量)
若修改的是inodes的 soft/hard值,表示规定用户可以创建的文件个数.
[root@localhost test]# edquota -u quota1 -->修改针对quota1用户的配置
Disk quotas for user quota1 (uid 500):
Filesystem blocks soft hard inodes soft hard
/dev/sdb1 0 100000 200000 0 0 0
[root@localhost test]# edquota -u quota2 -->修改针对quota2用户的配置
Disk quotas for user quota2 (uid 501):
Filesystem blocks soft hard inodes soft hard
/dev/sdb1 0 100000 200000 0 0 0
[root@localhost test]# edquota -g myquota -->修改针对myquota组的配置
Disk quotas for group myquota (gid 500):
Filesystem blocks soft hard inodes soft hard
/dev/sdb1 251200 100000 300000 3 0 0
这样配置表示quota1,quota2用户最多使用200M的磁盘空间,超过100M就发出警告并进入倒计时,而myquota组最多使用300M的磁盘空间。也就是说,虽然quota1,quota2都有200M的最大磁盘空间能使用权限,但他们都属于myquota组,他们的总量不得超过300M.
修改权限
[root@localhost test]# chmod 777 .
[root@localhost test]# ll -d
drwxrwxrwx. 3 root root 4096 8月 23 09:36 .
切换quota1用户,进行测试
[root@localhost test]# su quota1
[quota1@localhost test]$ dd if=/dev/zero of=bigfile1 bs=1M count=150
sdb1: warning, user block quota exceeded. -->警告
记录了150+0 的读入
记录了150+0 的写出
157286400字节(157 MB)已复制,1.02545 秒,153 MB/秒
再写入一个大文件
[quota1@localhost test]$ dd if=/dev/zero of=bigfile2 bs=1M count=150
sdb1: write failed, user block limit reached.
dd: 正在写入"bigfile2": 超出磁盘限额 -->超过200M的部分就无法写入了
记录了46+0 的读入
记录了45+0 的写出
47513600字节(48 MB)已复制,0.381467 秒,125 MB/秒
切换quota2用户
[root@localhost test]# su quota2
[quota2@localhost test]$ ls
aquota.group aquota.user bigfile1 bigfile2 lost+found
[quota2@localhost test]$ dd if=/dev/zero of=bigfile3 bs=1M count 50
记录了50+0 的读入
记录了50+0 的写出
52428800字节(52 MB)已复制,0.410838 秒,128 MB/秒
修改警告时间
[root@localhost test]$ 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/sdb1 7days 7days
查看quota1的quota信息
[quota1@localhost test]$ quota -u quota1
Disk quotas for user quota1 (uid 500):
Filesystem blocks quota limit grace files quota limit grace
/dev/sdb1 200000* 100000 200000 6days 2 0 0 -->已经进入警告的倒计时了
查询quota2的quota信息
[root@localhost test]# quota -u quota2
Disk quotas for user quota2 (uid 501):
Filesystem blocks quota limit grace files quota limit grace
/dev/sdb1 51200 100000 200000 1 0 0
查询myquota组的quota信息
[root@localhost test]# quota -g myquota
Disk quotas for group myquota (gid 500):
Filesystem blocks quota limit grace files quota limit grace
/dev/sdb1 251200* 100000 300000 6days 3 0 0
总结:
quotacheck [ -gubcfinvdMmR ] [ -F quota-format ] -a | filesystem
-a 检查所有/etc/mtab中挂在的文件系统
-u 只检查用户的quota
-g 只检查用户组的quota
quota
不使用任何参数,查询当前用户的quota信息
-u username 查询某用户的quota信息
-g groupname 查询某用户组的quota信息
edquota
-u username 编辑某用户的quota配置
-g groupname 编辑某用户组的quota配置
-t 编辑警告时间的配置
还有一个综合查询命令是
repquota
-a 报告所有支持quota的文件系统
-u 报告针对user的quota信息
-g 包裹针对group的quota信息
一般三个参数一起使用
[root@localhost test]# repquota -aug
*** Report for user quotas on device /dev/sdb1
Block grace time: 7days; Inode grace time: 7days
Block limits File limits
User used soft hard grace used soft hard grace
----------------------------------------------------------------------
root -- 20 0 0 2 0 0
quota1 +- 200000 100000 200000 6days 2 0 0
quota2 -- 51200 0 0 1 0 0
*** Report for group quotas on device /dev/sdb1
Block grace time: 7days; Inode grace time: 7days
Block limits File limits
Group used soft hard grace used soft hard grace
----------------------------------------------------------------------
root -- 20 0 0 2 0 0
myquota +- 251200 100000 300000 7days 3 0 0

Linux操作系统——网络配置与SSH远程安装完VMware与系统后,需要进行网络配置。第一个目标为进行SSH连接,可以从本机到VMware进行文件传送,首先需要进行网络配置。1.下载远程软件首先需要先下载安装一款远程软件:FinalShell或者xhell7FinalShellxhell7FinalShell下载:Windows下载http://www.hostbuf.com/downloads/finalshell_install.exemacOS下载http://www.hostbuf.com/downloads/finalshell_install.pkg2.配置CentOS网络安装好
文章目录一基础定义二创建逻辑卷2-1准备物理设备2-2创建物理卷2-3创建卷组2-4创建逻辑卷2-5创建文件系统并挂载文件三扩展卷组和缩减卷组3-1准备物理设备3-2创建物理卷3-3扩展卷组3-4查看卷组的详细信息以验证3-5缩减卷组四扩展逻辑卷4-1检查卷组是否有可用的空间4-2扩展逻辑卷4-3扩展文件系统五删除逻辑卷5-1备份数据5-2卸载文件系统5-3删除逻辑卷5-4删除卷组5-5删除物理卷六LVM逻辑卷缩容6-1缩容注意事项6-2标准缩容步骤一基础定义LVM,LogicalVolumeManger,逻辑卷管理,Linux磁盘分区管理的一种机制,建立在硬盘和分区上的一个逻辑层,提高磁盘分
如何在Ruby中获取linux系统(这必须适用于Fedora、Ubuntu等)的软件/硬件信息? 最佳答案 Chef背后的优秀人才,拥有一颗名为Ohai的优秀gemhttps://github.com/opscode/ohai以散列形式返回系统信息,例如操作系统、内核、规范、fqdn、磁盘、空间、内存、用户、接口(interface)、sshkey等。它非常完整,非常好。它还会安装命令行二进制文件(也称为ohai)。 关于ruby-如何在Ruby中获取linux系统信息,我们在Stack
我在LinuxMint17.2上。我最近使用apt-getpurgeruby删除了ruby。然后我安装了rbenv然后rbenvinstall2.3.0所以现在,~/.rbenv/versions/2.3.0/bin/ruby存在。但是现在,我无法执行geminstallrubocop。我明白了:$geminstallrubocoprbenv:gem:commandnotfoundThe`gem'commandexistsintheseRubyversions:2.3.0但是我可以~/.rbenv/versions/2.3.0/bin/geminstallrubocop。但是,
我是Ruby和RoR的新手。我有一个带有Ubuntu镜像的干净Linode实例,我想从源代码编译Ruby而不是使用apt-get。我已经在谷歌上搜索了执行此操作的说明,但经过一些尝试后,当我尝试运行一些教程示例时,我不断收到有关缺少zlib和其他一些包的错误。任何人都可以给我详细的说明(或链接),教我如何在从源代码编译Ruby之前安装必要的必备包吗?我的目的是编译Ruby的最新稳定版本,然后安装Rubygems和Rails。提前感谢您的帮助!!! 最佳答案 Thisblogpost涵盖从源代码编译ruby所需的包和安装过程;它引
目录POSIXAPI大集合五元组三次握手的过程,内核协议栈分析listen函数DDOS攻击,洪水攻击DDOS攻击的应对措施数据发送 怎么保证顺序?如何保证包地顺序到达(序号+确认应答机制+重传)TCP断开连接的过程问题1.大量的CLOSE_WAIT+FIN_WAIT2是为啥?time_wait状态存在的原因?POSIXAPI大集合五元组(sip,sport,dip,dport,protocol)三次握手的过程,内核协议栈分析内核协议栈中是有内核数据结构的. 我们send/write数据,都是先发送到内核协议栈中,然后由内核协议栈封装发送到物理介质中传输到对端的对端的接收过程也是经有内核协议栈
背景:Linuxexport命令用于设置或显示环境变量。在shell中执行程序时,shell会提供一组环境变量。export可新增,修改或删除环境变量,供后续执行的程序使用。export的效力仅限于该次登陆操作。语法:export[-fnp][变量名称]=[变量设置值]参数说明:-f 代表[变量名称]中为函数名称。-n 删除指定的变量。变量实际上并未删除,只是不会输出到后续指令的执行环境中。-p 列出所有的shell赋予程序的环境变量。实例:列出当前所有的环境变量#export-p//列出当前的环境变量值定义环境变量赋值#exportMYENV=7//定义环境变量并赋值添加环境变量:默认保存在
Nginx安装1.官网下载Nginx2.使用XShell和Xftp将压缩包上传到Linux虚拟机中3.解压文件nginx-1.20.2.tar.gz4.配置nginx5.启动nginx6.拓展(修改端口和常用命令)(一)修改nginx端口(二)常用命令1.官网下载Nginxhttp://nginx.org/en/download.html这里我下载的是1.20.2版本,大家按需下载对应稳定版即可2.使用XShell和Xftp将压缩包上传到Linux虚拟机中没有XShell可以参考《Linux操作系统CentOS7连接XShell》3.解压文件nginx-1.20.2.tar.gz1)检查是否存
Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法,Linux…感兴趣就关注我吧!你定不会失望。目录1.ls显示当前目录下的文件内内容2.pwd-显示用户当前所在的目录3.cd-改变工作目录。将当前工作目录改变到指定的目录下1.cd-回到上一次待的工作空间2.cd..返回上一层目录1.相对路径:cd../aurora2.绝对路径:cd/home/aurora/lesson1/aurora3.cd~进入用户家目录4.cd/进入root目录4.mkdir-新建目录5.rmdir/rm-删除1.rmdir删除空文件夹2.rm删除1.rm-f2.rm-i3.rm-r1.ls显示当前目
文章目录🔥Linux系统目录结构🔥Linux用户和用户组🔥Linux用户管理🔥Linux系统目录结构文件系统组织结构⭐ /lib系统开机所需要最基本的动态链接共享库,其作用类似于Windows里的DLL文件。几乎所有的应用程序都需要用到这些共享库。⭐ /lost+found一般情况下是空的,当系统非法关机后,这里就存放了一些文件。⭐ /etc所有系统管理所需要的配置文件和子目录my.conf⭐ /usr用户的很多应用程序和文件都放在这个目录下。⭐ /bin是Binary的缩写,这个目录存放着经常使用的命令⭐ /sbin(usr/sbin、/usr/local/sbin)sbin就是peruse