本文转载自:https://blog.csdn.net/BlackEnn/article/details/50787092

1.查看/dev/sda1下磁盘分区的block大小:

2.查看单个inode及block大小:

3.有关inode的知识:

Inode 用户的属性信息:

①首页的目录索引就相当于Inode;

②每一页就是一个Block;

③整本书就是一个磁盘或分区。

“df -i查看挂载的磁盘,inode情况”

有关inode小结:学会阶段性的知识,做小结是学好linux运维的好习惯:

(1)磁盘分区格式化为ext4文件系统后会生成一定数量的inode和block;

(2)inode是索引节点,作用是存放文件的属性信息以及作为文件的索引,指向文件的实体->Block;

(3)ext3/ext4文件系统的Block存放的是文件的实际内容;

(4)inode是一块存储空间,Centos6非启动分区inode默认大小字节为256字节,Centos5为128字节;

(5)inode是一串数字,不同文件对应的inode(一串数字)在文件系统中是唯一的;

(6)如果一个文件很大,可能占多个block,如果一个文件很小,至少占一个,并且剩余空间浪费了;

(7)inode相同的文件,互为硬链接的文件;

(8)一个文件被创建后至少要占用一个inode和一个block;

(9)如果文件很小,也至少要占用一个block并且剩余空间不能被使用;

(10)inode大小和总量查看:

dumpe2fs /dev/sda2|egrep -i "block size|Inode Size“

dumpe2fs /dev/sda3|egrep -i "block count|Inode count"

(11)查看inode总量与使用量命令:df -i:

4.有关Block的知识:

(1)磁盘Blck读取数据是按block为单位读取的;

(2)一个文件可能占用多个block,每读取一个block就会消耗一次磁盘IO;

(3)如果要提升磁盘的性能的话,那么就要尽可能一次性地读取数据数量足够多;

(4)一个block只能存放一个文件的内容,无论内容多么的小。如果block的大小为4k,那么存放1K的文件,剩余3K就浪费了;

(5)block并非越大越好,Block太大对于小文件的存放就会浪费磁盘空间;

例如:1000K的文件,Block为4K,占用250个Block;

Block为1K,占用1000个Block。

消耗磁盘IO分别为:1000次与250次,试问谁的效率更高?

(6)大文件(大于16K)一般设置Block大一点;

小文件(小于16K)一般设置Block小一点。

(7)Blcok太大例如4K,文件都是0.1K的,大量浪费磁盘空间

(8)Block太小例如1K,文件都是1000K,消耗磁盘IO

(9)Block设置也是磁盘化分区的时候:

mkfs.ext4 -b 2048 -1 2056 /dev/sdb

(10)文件较大时Block设置大一些会提升磁盘效率;

(11)/ext3/ext4 一般设置为4K。

5.企业面试题

①一个100M(100000K)文件的磁盘分区,分别写入1K文件与写入1M文件,分别可以写多少个?

解答思想:

a.Inode是存放文件属性信息的,默认大小128byte(C58),256byte(C64);

b.Block是存放文件内容的,默认的大小1K(boot(引导区))或4K非系统分区;

c.一个文件至少要占一个Inode和一个block;

d.默认分区常规情况下,inode数量足够而block数量消耗的会更快。

正确解答:

1.默认分区常规情况下,对大文件来讲,inode是足够的,而block数量会消耗得更快,block为4K的情况下,1M的文件不会有磁盘浪费的情况,所以文件数量大概为100/1=100个;

2.对于小文件0.1K,inode会消耗得更快,默认分区的时候,block的数量是大于inode的数量的,每个文件会占用一个inode与一个block,所以最终文件的数量:inode会先消耗完,文件总量是inode的数量。

②如果向磁盘写入数据,提示:No space left on device,通过df -h查看磁盘空间,发现没满,为什么?

a.可能是inode耗尽了;

b.df -i查看是否耗尽了inode数量;

c.企业工作中临时邮件队列 /var/spool/clientmquene目录只有安装了sendmail服务才会有,是sendmail邮件的临时队列。Centos5.8默认就会安装sendmail,Centos6.6默认没有sendmail。

《Inode与Block重要知识总结核心讲解》【转】的更多相关文章

  1. 转《在浏览器中使用tensorflow.js进行人脸识别的JavaScript API》

    作者 | Vincent Mühle 编译 | 姗姗 出品 | 人工智能头条(公众号ID:AI_Thinker) [导读]随着深度学习方法的应用,浏览器调用人脸识别技术已经得到了更广泛的应用与提升.在 ...

  2. face-api.js:一个在浏览器中进行人脸识别的 JavaScript 接口

    Mark! 本文将为大家介绍一个建立在「tensorflow.js」内核上的 javascript API——「face-api.js」,它实现了三种卷积神经网络架构,用于完成人脸检测.识别和特征点检 ...

  3. TensorFlow.js之安装与核心概念

    TensorFlow.js是通过WebGL加速.基于浏览器的机器学习js框架.通过tensorflow.js,我们可以在浏览器中开发机器学习.运行现有的模型或者重新训练现有的模型. 一.安装     ...

  4. 在Java中直接调用js代码(转载)

    http://blog.csdn.net/xzyxuanyuan/article/details/8062887 JDK1.6版添加了新的ScriptEngine类,允许用户直接执行js代码. 在Ja ...

  5. 第十一章:WEB浏览器中的javascript

    客户端javascript涵盖在本系列的第二部分第10章,主要讲解javascript是如何在web浏览器中实现的,这些章节介绍了大量的脚本宿主对象,这些对象可以表示浏览器窗口.文档树的内容.这些章节 ...

  6. 在Java中直接调用js代码

    JDK1.6版添加了新的ScriptEngine类,允许用户直接执行js代码. 在Java中直接调用js代码 不能调用浏览器中定义的js函数,会抛出异常提示ReferenceError: “alert ...

  7. TensorFlow.js入门(一)一维向量的学习

    TensorFlow的介绍   TensorFlow是谷歌基于DistBelief进行研发的第二代人工智能学习系统,其命名来源于本身的运行原理.Tensor(张量)意味着N维数组,Flow(流)意味着 ...

  8. JavaScript权威指南--WEB浏览器中的javascript

    知识要点 1.客户端javascript window对象是所有客户端javascript特性和API的主要接入点.它表示web浏览器的一个窗口或窗体,并且可以用window表示来引用它.window ...

  9. 解决webkit浏览器中js方法中使用window.event提示未定义的问题

    这实际上是一个浏览器兼容性问题,根源百度中一大堆,简要说就是ie中event对象是全局变量,所以哪里都能使用到,但是webkit内核的浏览器中却不存在这个全局变量event,而是以一个隐式的局部变量的 ...

  10. JS Date当前时间:获取日期时间方法在各浏览器中的差异

    转自:http://www.feiesoft.com/00047/<script type="text/javascript"> // JS Date当前时间获取方法在 ...

随机推荐

  1. C# 6新特性简单总结

    最近在看<C#高级编程 C# 6&.NET Core 1.0>,会做一些读书笔记,也算对知识的总结与沉淀了. 1.静态的using声明 静态的using声明允许调用静态方法时不使用 ...

  2. 49、android ListView几个比较特别的属性

    由于这两天在做listView的东西,所以整理出来一些我个人认为比较特别的属性,通过设置这样的属性可以做出更加美观的列表 android:stackFromBottom="true" ...

  3. 《从零开始学Swift》学习笔记(Day 34)——静态属性是怎么回事?

    原创文章,欢迎转载.转载请注明:关东升的博客 我先来设计一个类:有一个Account(银行账户)类,假设它有3个属性:amount(账户金额).interestRate(利率)和owner(账户名). ...

  4. FTP上传和下载文件的应用

    FTP(File Transfer Protocol)协议主要用来在网络上进行文件传输.FTP通讯除了有一个默认的端口21外,还有其他端口,同城两个端口同时进行数据传输.一个是默认的端口(通常为21) ...

  5. POJ 1039 Pipe【经典线段与直线相交】

    链接: http://poj.org/problem?id=1039 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22013#probl ...

  6. JavaScript数据结构与算法-集合练习

    集合的实现 function Set () { this.dataStore = []; this.add = add; this.remove = remove; this.size = size; ...

  7. Power Systems 虚拟化简介

    本文向您详细地介绍了 Power System 虚拟化相关的技术和亮点,让您对这些最新的虚拟化技术有一个全面的了解.本文来自 IBM Systems Magazine for AIX 中文版. 自从引 ...

  8. flask信号

    骚师博客:信号 信号你就可以这么理解,请求比喻成赛车,请求走的流程就是赛车道,而信号坐落在赛车道上的加油站和维修站,信号注册的函数好比维修站的人,每经过维修站并且维修站里有人就进行维修 信号这里理解: ...

  9. ES6学习笔记(三)——数值的扩展

    看到这条条目录有没有感觉很枯燥,觉得自己的工作中还用不到它所以实在没有耐心看下去,我也是最近得闲,逼自己静下心来去学习去总结,只有在别人浮躁的时候你能静下心来去学去看去总结,你才能进步.毕竟作为前端不 ...

  10. ffmpeg参数使用说明2

    附录一(ffmpeg参数说明): [参数] [说明] [示例] -i "路径" 指定需要转换的文件路径 -i "C:\nba.wmv" -y 覆盖输出文件,即如 ...