[root@localhost~]#序言
首先讲讲昨天关于缩容失败,开不机的解决方法;ACL权限也算是一个很重要的知识点,不难,但是很实用;
磁盘配额一般不需要自己弄,但是要懂得原理。
剩下的就是编译属于自己的linux内核,根据自己的需求不论是硬件还是其他,你都可以定制,但是编译成功与否这个我不敢保证,我也编译了两次才成功的。


 开班第十三天:

[root@localhost~]#今天的课程大纲
.缩容失败原因以及开不了机解决方法
.Linux中ACL权限的详解
.讲解一下磁盘配额的知识
.编译属于自己的linux内核

详细讲解:  

[root@localhost~]#缩容失败原因以及开不了机解决方法

  昨天为了增加lvroot的容量,而去减少lvhome的大小,在减少的过程中,有些人可能会误操作先减少了lv,再减少文件系统,这样问题就出现了,那多出来的文件系统,放在那里,所以正确的方法是跟动态扩容的顺序反一反。问题出现了,那么我们就需要解决。

  开不了机的主要原因还是开机自动挂载了/home,而/home本身已经损坏,所以开机的时候就会卡在挂载/home的地方,开机可以进入字符界面,提示输入密码,但是进去不了图形界面。解决方法如下:

  1. 输入密码之后,vim /etc/fstab,进入文件注释掉挂载/home的那一条,如果提示权限不足,进不去fstab,那么我们使用mount -o remount,tw /,重新以读写的方式挂载根文件系统。这样就可以了。
  2. 还有一个问题需要注意,查看fstab的时候,看看挂载选项写的是/dev/....还是uuid,如果是uuid,就需要改成/dev/....,因为文件系统变化,uuid变化,所以下次想要挂载的时候会不成功。
[root@localhost~]#Linux中ACL权限的详解

  ACL权限更加细化的设置UGO权限,那么使用ACL需要满足一下两点:

  1. ACL是文件系统的特性,有些文件系统是不支持的,例如ntfs,fat32.
  2. 就算支持,也需要开启ACL,假如我开启根的ACL,mount -o remount,acl /,如果想开机自动开启,编辑/etc/fstab。(可以使用mount来查看是否开启了ACL权限)

  如何来使用ACL权限呢,ACL权限可以针对某个用户,某个组,来单独设置权限,使用普通的UGO是难以实现的,现在有个需求,/home/libin/libin.txt,我想为libin这个用户单独对这个文件有rwx权限。

  1. 设置ACL权限,setfacl -m u:libin:rwx /home/libin/libin.txt,这样就设置好了。(会出现一个+号)
  2. 查看ACL权限,使用getfacl /home/libin/libin.txt。

  

  3.setfacl -x u:libin /home/libin/libin.txt,移除用户libin对这个文件的ACL权限。

  4.setfacl -b /home/libin/libin..txt,移除这个文件上所有的ACL权限。(+号没有了)

  5.设置目录的默认ACL权限,意思就是这个目录里新建的文件都会继承这个目录上的ACL权限,setfacl -d -m u:libin:rwx /home/libin,移除这个默认使用参数-k。

[root@localhost~]#讲解一下磁盘配额的知识

  磁盘配额是啥玩意,它是根据设置inode和block来限制文件系统可以使用的容量大小。(inode和block不懂的可以看以前的教程)。我们可以手动设置配额,假设我让一个文件系统只有一个inode,那么你可以做的就是在我的磁盘上只能放一个文件,第二个都放不进去。(感觉可以恶搞)

  磁盘配额使用要求:(类似ACL)

  1. 文件系统支持
  2. 开启磁盘配额,mount -o remount,usequota,grpquota /,同样开机启动也需要编辑fstab。

  现在我针对libin这个用户在/home分区下设置磁盘配额,

  1.首先使用quotacheck -ugvc /home,作用是检查磁盘的使用空间与限制。

  2.现在我已经开启了磁盘配额,使用quotaon /home,开启。

  3.现在我们用root用户设置libin针对/home分区的磁盘配额,使用edquota -u -f /home libin,其中block和inode是已经使用的,我们针对soft和hard设置,假设我设置inode后面的hard为15,soft为13,表示libin在/home中可以总共放置15个文件,到13个时候会警告快要满了。

  

  4.到达soft的限制后,一般是七天之内还可以添加文件,七天之后就就算你没有到达hard,也不能添加了,现在我们设置到达soft之后还可以多少天内添加文件,使用 edquota -u -f /home -T libin。

  5.关闭磁盘配额很简单,quotaoff /home。

  6.这里我做了一个例子,针对libin用户在/boot分区下,只能创建6个文件,且4个之后就会警告。还是例子更能让人理解一点。

  

  

  7.记住上面这些设置soft和hard的命令都只有root才能执行,edquota是设置libin用户在某个目录的磁盘配额,而且libin用户要进入到这个目录才能使用quota查看自己在这个目录的配额。

[root@localhost~]#编译属于自己的linux内核

  编译内核,听起来还是蛮高端的,其实很简单,我们编译内核主要有以下几个原因:

  1. 得到内核源代码(可以到kernel.org下载,不过慢,我提供两个)
  2. 解压源代码
  3. 编译内核
  4. 安装

  

  我习惯把内核解压到/usr/src目录中,tar /内核 -C /usr/src,进入解压之后的文件夹,cd /usr/src/内核.我们是初学者,要是有一个图形界面帮助我们就更好了,linux提供了,我们进入目录之后,直接执行make menuconfig,就可以打开一个图形界面,所有内核的设置都在这里。

  

  几千个,我说不过来,你不要的模块,空格去掉就行,不过我劝大家第一次不要修改太多,要不然怎么失败的都不知道,我这里开启了ntfs支持(默认不支持的),去掉了wireless(wifi),蓝牙。修改了内核编译出来的后缀名为自己的-625.libin。

  设置好之后,就可以开始编译了,执行make all && make modules_install && make install ,这个过程很漫长,一般在半个小时以上两个小时以下,所以慢慢等。。。。

  我这里成功编译出来了,并且也安装上了,怎么看是否是用的自己的内核呢?

  1. 查看ls /boot/grub/grub.conf 查看是否有新的内核选项
  2. 开机之后,uname -r 查看。

  

  自己的内核,看起来还是挺装x的。大家有什么不懂的可以私信我,然后我为你们详细解答。我讲的可能不是很清楚,因为太多了。

总结:

[root@localhost~]#来自爱家人爱老婆的IT男
对于linux的扩容缩容,一定要提前做好备份。内核编译不难,主要是很难搞清楚一些模块的依赖情况,所以现在的我还没有能力去深入了解这些东西。
一个一个字打出来的,挺累的,不过为了大家为了自己,挺值得的,希望大家点一波关注!谢谢各位!
博客园:爱家人爱老婆的IT男
QQ群:145252709,我会上传资源,同时会有很多大神跟你们讨论学习分享
微信公众号:程序猿的野生香蕉【获取文章中出现的工具】

<实训|第十三天>linux中ACL权限控制以及磁盘配额,附编译属于自己的linux内核的更多相关文章

  1. <实训|第九天>掌握linux中普通的权限控制和三种特殊的权限(sst),做合格的运维工程师

    linux中,权限的学习是必不可少的,不论是作为一名运维工程师或者是单一的管理者,学习好linux中的权限控制,你就可以保护好自己的隐私同时规划好你所管理的一切. 权限的学习是很多的,不要认为自己已经 ...

  2. Linux系统——ACL权限控制及特殊权限

    ACL权限控制 ACL(access control list),可以提供除属主.属组.其他人的rwx权限之外的细节权限设定 ACL的权限控制 (1)User 使用者 (2)Group 群组 (3)M ...

  3. Linux下ACL权限控制以及用sudo设置用户对命令的执行权限

    ACL权限分配 1.setfacl命令设置文件权限 setfacl -m u:user1:rw root.txt setfacl -m u:user2:rwx root.txt 2.getfacl命令 ...

  4. Linux - 文件ACL权限控制

    getfacl 1.test # 查看文件ACL权限 setfacl -R -m u:xuesong:rw- 1.test # 对文件增加用户的读写权限 -R 递归

  5. linux:ACL权限

    ACL权限是为了防止权限不够用的情况,一般的权限有所有者.所属组.其他人这三种,当这三种满足不了我们的需求的时候就可以使用ACL权限: 比如:一个网络老师,给一个班的学员上课,他在linux的根目录下 ...

  6. [转]Linux中文件权限目录权限的意义及权限对文件目录的意义

    转自:http://www.jb51.net/article/77458.htm linux中目录与文件权限的意义 一.文件权限的意义 r:可以读这个文件的具体内容: w:可以编辑这个文件的内容,包括 ...

  7. zookeeper的ACL权限控制

    ACL:Access Control List  访问控制列表 1.  简介 0.概述 ACL 权限控制,使用:scheme:id:perm 来标识,主要涵盖 3 个方面: 权限模式(Scheme): ...

  8. phalcon: 目录分组后的acl权限控制

    phalcon: 目录分组后的acl权限控制 楼主在做acl权限的时候,发现官方的acl只能针对未分组的目录,如下: app/ ___|./controller ___|./logic ___|./p ...

  9. 1.ZooKeeper ACL权限控制

    参考:https://blog.csdn.net/liuxiao723846/article/details/79391650 ZK 类似文件系统,Client 可以在上面创建节点.更新节点.删除节点 ...

随机推荐

  1. Innodb行锁源码学习(一)

    Innodb是mysql数据库中目前最流行的存储引擎,innodb相对其它存储引擎一个很大的特点是支持事务,并且支持行粒度的锁.今天我重点跟大家分享下innodb行锁实现的基础知识.由于篇幅比较大,文 ...

  2. 按要求编写Java应用程序: (1)编写西游记人物类(XiYouJiRenWu) 其中属性有:身高(height),名字(name),武器(weapon) 方法有:显示名字(printName),显示武器(printWeapon) (2)在主类的main方法中创建二个对象:zhuBaJie,sunWuKong。并分别为他 们的两个属性(name,weapon)赋值,最后分别调用printName,

    package com.hanqi.test; public class xiyoujirenwu { private double height;// 身高 private String name; ...

  3. Oracle索引梳理系列(一)- Oracle访问数据的方法

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  4. MySQL运行状态show status中文详解(转)

    要查看MySQL运行状态,要优化MySQL运行效率都少不了要运行show status查看各种状态,下面是参考官方文档及网上资料整理出来的中文详细解释: 状态名 作用域 详细解释 Aborted_cl ...

  5. SQL Server 分隔字符串函数实现

    在SQL Server中有时候也会遇到字符串进行分隔的需求.平时工作中常常遇到这样的需求,例如:人员数据表和人员爱好数据表,一条人员记录可以多多人员爱好记录,而往往人员和人员爱好在界面展示层要一并提交 ...

  6. js有关时间日期的操作

    var myDate = new Date();var date_string = myDate.getFullYear()+""+((myDate.getMonth()+1)&l ...

  7. 怎么使PUTTY一直连接

    如何才能保证PUTTY一直连接,即使我们好长时间不去敲命令,也让它一直连接着? PuTTY的设置方法是:在Connection里面有个Seconds between keepaliaves.这里就是每 ...

  8. appium 常用api介绍(1)

    前言:android手机大家都很熟悉,操作有按键.触摸.点击.滑动等,各种操作方法可以通过api的方法来实现. 参考博文:http://blog.csdn.net/bear_w/article/det ...

  9. DPM检测模型 训练自己的数据集 读取接口修改

    (转载请注明作者和出处 楼燚(yì)航的blog :http://www.cnblogs.com/louyihang-loves-baiyan/ 未经允许请勿用于商业用途) 本文主要是针对上一篇基于D ...

  10. js获取鼠标位置的各种方法

    在一些DOM操作中我们经常会跟元素的位置打交道,鼠标交互式一个经常用到的方面,令人失望的是不同的浏览器下会有不同的结果甚至是有的浏览器下没结果,这篇文章就上鼠标点击位置坐标获取做一些简单的总结,没特殊 ...