让fdisk输出更准确合理
注意:新版本的fdisk默认输出已经正确合理了,本文只适用于旧版本的fdisk.
1 无option选项参数的输出
[root@localhost ~]# fdisk -l Disk /dev/sda: 160.0 GB, 160041885696 bytes
255 heads, 63 sectors/track, 19457 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0xf0b1ebb0 Device Boot Start End Blocks Id System
/dev/sda1 * 1 7295 58592256 83 Linux
/dev/sda2 7295 19458 97695745 5 Extended
/dev/sda5 7295 17021 78124032 83 Linux
/dev/sda6 17021 18966 15624192 83 Linux
/dev/sda7 18967 19458 3945472 82 Linux swap / Solaris
[root@localhost ~]#
此时输出结果基于远古时代的CHS硬盘寻址模式,CHS早就被业界淘汰了,纯属历史遗留的概念,只有 可能在某些BIOS里还存在。但是目前还有很多资料或软件出现相关信息,比如fdisk -l的结果。为了顾及知识完整性,还是简单做一下介绍,有兴趣的同学可以去Internet上查找关键词CHS。话说最早的硬盘有多个盘片组成,每个盘片 都对应一个磁头(Head)来扫描它,一个盘片分成很多同心圆环,每一个圆环叫做一个轨道(Track),每个轨道又被平均分成多个弧段也叫扇区 (Sector)。需要注意的是,这里的同心圆环,不论半径大小,都被分成了相同数量的扇区,而每个扇区大大小是固定的512B。所以内环的数据密度一定 高于外环的数据密度了。所有盘片上对应的轨道(Track)共同组成一个柱面(Cylinder)。就我自己而言,没见过超过2个盘片的硬盘,所以这个柱 面其实是很矮的。
CHS定位原理也很简单,首先找到柱面(C),然后在此柱面上找到盘面(H),最后在 柱面和盘面切割的轨道上找到扇区(S)。其实理论上也可以先找到盘面然后再找轨道和扇区。之所以是CHS这个顺序是因为当初的硬盘构造决定的,所有磁头都 固定在同一个装置上,相对位置不变,所以所有磁头都是一起移动的。这样如果相邻数据在同一柱面上的话,则无需移动磁头就能全部读写,所以效率最高。不扯这 些了,毕竟CHS早就淘汰了。回到上面的输出结果,第一行显示/dev/sda这个硬盘总容量为160G,第二行显示磁盘有255个磁头(盘面),每个磁 道有63个扇区,同心圆环有19457个。难道这个硬盘真的有255个盘面?显然这是不可能的。之所以会有这样的输出就是因为兼容CHS模式。而255个 磁头63个扇区都是CHS的极限值,在这里并不代表实际的硬盘物理结构。第三行的Units表示的是一个柱面能存储多少字节数据,即 255*63*512,这对于现在的硬盘显然也是没有什么意义的。然而在输出结果的分区列表中的start和end列却使用了unit作为度量单位,也就 是说分区的对齐单位是柱面,显得非常不够精确。Blocks列的单位是KB,与units无关。
2 强烈建议给出的option参数
如果我们不加参数运行fdisk,输出如下结果。
[root@localhost ~]# fdisk /dev/sda WARNING: DOS-compatible mode is deprecated. It's strongly recommended to
switch off the mode (command 'c') and change display units to
sectors (command 'u'). Command (m for help):
此处给出了警告信息:DOS兼容模式已经废弃,强烈建议执行c命令切换模式,并且使用u命令把输出的unit由柱面改为扇区。按照提示进行操作如下:
Command (m for help): c
DOS Compatibility flag is not set Command (m for help): u
Changing display/entry units to sectors Command (m for help): p Disk /dev/sda: 160.0 GB, 160041885696 bytes
255 heads, 63 sectors/track, 19457 cylinders, total 312581808 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0xf0b1ebb0 Device Boot Start End Blocks Id System
/dev/sda1 * 2048 117186559 58592256 83 Linux
/dev/sda2 117188606 312580095 97695745 5 Extended
/dev/sda5 117188608 273436671 78124032 83 Linux
/dev/sda6 273438720 304687103 15624192 83 Linux
/dev/sda7 304689152 312580095 3945472 82 Linux swap / Solaris Command (m for help):
可见此时的打印结果中分区列表的Unit不再以柱面为单位,而是以扇区了。而扇区确实是当前大多数硬 盘以及逻辑硬盘(LUN)的最小存储单位,而且也采用LBA这种线性寻址方式。既然fdisk能给出警告,为什么不把默认改为正确的方式呢?比较发现新版 本的fdisk确实默认已经能正确显示了,当遇到老版本的fdisk时,还是需要添加cu参数。
在非交互的fdisk -l下,也只需使用 fdisk -cul 即可正确显示分区信息了。
[root@localhost ~]# fdisk -cul Disk /dev/sda: 160.0 GB, 160041885696 bytes
255 heads, 63 sectors/track, 19457 cylinders, total 312581808 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0xf0b1ebb0 Device Boot Start End Blocks Id System
/dev/sda1 * 2048 117186559 58592256 83 Linux
/dev/sda2 117188606 312580095 97695745 5 Extended
/dev/sda5 117188608 273436671 78124032 83 Linux
/dev/sda6 273438720 304687103 15624192 83 Linux
/dev/sda7 304689152 312580095 3945472 82 Linux swap / Solaris
顺便提一下,注意上面MBR和第一主分区,以及各分区之间并不是紧密相连的,而是有一些“未使用”的扇区。我能想到的一个原因就是,GRUB的一部分代码就是存在于分区之间的夹缝之中。
让fdisk输出更准确合理的更多相关文章
- plsqldevloper + orcal环境搭建
移动信息安全的漏洞和逆向原理 程序员11月书讯,评论得书啦 Get IT技能知识库,50个领域一键直达 关闭 PL/SQL Developer安装配置实践 2014-04-23 1 ...
- 定制kickstart重建CentOS7.5镜像用于U盘引导安装
有什么问题或者疑惑,可以留言,全力解答. ISO 镜像制作 U 盘安装盘 U盘安装CentOS7.4 U盘实现CentOS7.3全自动安装系统 https://www.cnblogs.com/pany ...
- 【腾讯Bugly干货分享】腾讯验证码的十二年
本文来自于腾讯bugly开发者社区,未经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/581301b146dfb1456904df8d Dev Club 是一个交流移动 ...
- 【Dev Club 分享】腾讯验证码的十二年
源:http://mp.weixin.qq.com/s?__biz=MzA3NTYzODYzMg==&mid=2653578147&idx=3&sn=94a8f8f8b4a23 ...
- Linux 使用fdisk添加新分区
Linux系统由于数据累计增长.前期存储规划不合理等诸多因素,出现存储不够用的情况时,此时就需要扩展逻辑分区或添加新的逻辑分区.下面介绍一下通过使用fdsik添加新的逻辑分区. 首先使用df命令检查文 ...
- linux fdisk命令使用
fdisk 对硬盘及分区的操作,进入fdisk 对硬盘操作阶段 我们可以对硬盘进行分区操作,前提是您把fdisk -l 弄明白了:通过fdisk -l ,我们能找出机器中所有硬盘个数及设备名称:比如上 ...
- fdisk分区硬盘并shell脚本自动化
最近工作需要用到对硬盘进行shell脚本自动化分区和mount的操作,google了一些资料,下面做个总结. 如果硬盘没有进行分区(逻辑分区或者扩展分区,关于两者概念,自行google),我们将无法将 ...
- 文件系统管理 之 实例解说 fdisk 使用方法
一.fdisk 的介绍: fdisk - Partition table manipulator for Linux ,译成中文的意思是磁盘分区表操作工具:本人译的不太好,也没有看中文文档:其实就是分 ...
- df、du、fdisk:Linux磁盘管理三板斧的使用心得(转载)
From:http://os.51cto.com/art/201012/240726_all.htm 作者介绍:李洋(博客),博士毕业于中科院计算所.10多年来一直从事计算机网络信息安全研发工作,曾主 ...
随机推荐
- 用MSBuild和Jenkins搭建持续集成环境(2)
http://www.infoq.com/cn/articles/MSBuild-2 作者 Mustafa Saeed Haji Ali ,译者 李剑 发布于 2012年10月23日 | 注意: ...
- Struts2原码分析系列之一
struts2概述 在struts2的官网上有这么一句话,翻译为:Apache Struts2是一个为企业级应用打造的优秀的.可扩展的WEB框架,该框架旨在充分精简应用程序的开发周期,从而减少创建.发 ...
- gameObject, vector and transform
调用其它组件中成员 通过GameObject(游戏物体). Base class for all entities in Unity scenes. 是Unity场景里面所有实体的基类. 可以理解为 ...
- ELK kibana查询与过滤(17th)
在kibana中,可通过搜索查询过滤事务或者在visualization界面点击元素过滤. 创建查询 在Discover界面的搜索栏输入要查询的字段.查询语法是基于Lucene的查询语法.允许布尔运算 ...
- DiskFileItemFactory类---分析及运用
DiskFileItemFactory类 将请求消息实体中的每一个项目封装成单独的DiskFileItem (FileItem接口的实现) 对象的任务由 org.apache.commons.file ...
- Windows下配置使用MemCached
工具: memcached-1.2.6-win32-bin.zip MemCached服务端程序(for win) Memcached Manager win下的Mem ...
- 【BZOJ】【2038】小Z的袜子
填个坑吧,学习了莫队算法.我也忘记是看的哪位大牛的博客&代码学习的了T_T,如果您发现了的话请私信我,我会注明学自您的代码. 另外感谢@PoPoQQQ大神 好,进入正文,莫队算法,也算是一种暴 ...
- 剑指offer--面试题22
关键在于思路, 需要两个输入向量,而函数中需要一个辅助栈! 思路:以待判出栈序列为基础,逐个判断它与栈顶元素是否相等,相等则弹出且j++,这表明此元素可为出栈顺序元素,不相等则栈元素不断入栈,直至相 ...
- WCF基本概念
WCF是基于Windows平台下开发和部署服务的SDK.服务是一组公开的功能集合. 面向服务(Service Orientatio,SO)是一组原则的抽象, 面向服务的应用程序(SOA)将众多服务聚集 ...
- Windows10+IIS7.5上如何配置PHP站点
最近我一直在写PHP,但是我很喜欢微软的开发环境和Windows的硬件环境,我就想在IIS上配置一下PHP站点,这样用起来也比较方便,在经过各位前辈的文章学习后,自己整理了一个比较简单的图片为主的教程 ...