Linux磁盘设备基础
free -m 查看系统内存
[root@zhang /]# free -m
total used free shared buffers cached
Mem: 1004 226 777 0 29 150
-/+ buffers/cache: 46 957
Swap: 199 0 199
linux系统的特性是将系统不用的物理内存缓存起来,所以777不是系统真正的缓存,957才是
buffers是写入缓冲区,sync命令是将buffers缓冲区数据写入磁盘
cache为读出缓存,磁盘里的数据读出来存到cache里
磁盘的内部结构主要是包括:盘片、磁头、盘片主轴、控制电机、磁头控制器、数据转换器、磁盘接口、缓存等几个部分。
磁头组件:由读写磁头、传动手臂、传动轴三部分组成。
磁盘读取数据的工作原理是利用特定的磁粒子的极性来记录数据。
磁盘片:盘片是磁盘存储数据的真正载体
磁盘接口是磁盘与主机系统之间的连接部件。
磁盘类型:
IDE是早期的家用,被淘汰了
SCSI 早期的服务器领域 好用但是昂贵
SATA流行的家用领域 --SATA口磁盘又叫做串口磁盘 支持热插拔
SAS 流行的服务器领域 --结合了SATA和SCSI的优点而诞生的
FC—光纤通道 高端服务器
硬盘选择的小结:
1.主轴转数
2.磁盘接口和类型
固态磁盘普遍使用SATA接口
固态磁盘的优点:
启动快 读取延时小 碎片不影响读取 写入速度快 无噪音 防震
缺点:贵,容量小,读写寿命短,数据恢复难
1)企业级SAS应用
企业里最常见的工业级SAS硬盘是15000转/分 ---用于提供生产线上的普通对外提供服务的对外服务器。例如:生产线上的数据库业务,存储业务,图片业务。SAS是生产环境的首选
2)企业级SATA硬盘
SATA硬盘7200-10000转/分,常见容量为1T和2T。使用量大,要求不高使用SATA
3)SSD固态电子盘
一般用于数据量小并且有超大规模高并发业--可以通过磁盘加内存缓存的技术方式解决这个大规模并发问题
磁盘使用小结:
1.线上的业务,使用SAS
2.线下的业务,使用SATA
3.线上高并发、小容量的业务,使用SSD磁盘
4.根据数据的访问热度,智能分析分层从存储。智能分析的案例 淘宝(sata500G+ssd80G)
特别注意:
千万不要用SATA磁盘来做在线高并发服务的数据存储或数据库业务。
操作系统是以扇区为单位将信息存储在磁盘上的。每个扇区为512个字节
小结:
1.扇区大小是512字节
2.扇区主要分为两部分:标识符头标和数据段
3.标识符(头标):三维地址(哪个柱面(磁道),磁头号,哪个扇区),标识扇区是否可靠。
4.数据段: 数据和保护数据的纠错码(ECC)
磁道柱面扇区总括
1.一块磁盘有1个或多个盘片,一个盘片有两个磁头,磁头数=盘面数。 柱面数=磁道数
2.同一个盘面,以盘片中心为圆心,每个不同半径的圆形轨迹就是一个磁道
fdisk -l
磁盘大小=磁道数(=柱面数cylinders)*磁头数(head)*512字节*扇区数(sectors/track)
磁盘大小=柱面数*柱面大小(Unit)
磁盘读写原理小结:
1)磁盘是按照柱面为单位读写数据的,即先读取同一个盘面的某一个磁道,读完整个磁道之后,如果数据没有读完,磁头也不会切换到同一盘面的其他磁道,而是切换磁头
2)不同磁头间的切换是电子切换
磁盘基础知识回顾:
1)磁盘的作用:存储数据,物理设备。
3.5寸磁盘为例:
2)外部结构:
正面板:固定面板:产地,容量,日期,转数,品牌,条形码,跳线,电压,透气孔,内六角螺丝。
反面板:绿色控制电路板,上面有芯片,电容,电阻,缓存作用(free -m)等
Buffer写入缓冲区,cache读取缓存区
侧面:电源接口,跳线,数据接口(ide sata sas scsi)
3)内部结构:
磁盘片:2-14片 ,每个面都可以放数据
主轴:里面有轴承,马达
磁头组件:磁头,机械手臂,传动轴
前置控制电路,数据转换器,永久磁铁,步进电机(控制磁头径向移动)
核心组件:磁头及盘片
4)磁盘存取原理:
磁盘读数据时:将磁盘上的磁离子极性转换成电脉冲信号,然后通过数据转换器转换成电脑可以识别的数据。
5)磁盘读写数据的原理
磁盘读写数据时,按照柱面来读写数据的。可能会先读一个盘面的某一个磁道的数据,读完之后,在向下读取相同磁道,不同盘面的数据,知道所有盘面相同磁道的数据被读取完毕,切换到下一个柱面。这个切换过程叫做寻道,寻道要靠步进电机控制,让磁头做移动了,这是机械运动,因此很慢,写同理。
6)磁盘相关名词:
Disk 磁盘
Head 磁头
Sector 扇区
Track 磁道
Cylinder 柱面
Units 单元块(一个柱面的大小)
Block 磁盘块
inode 索引节点
主引导记录MBR的所在地:
0磁头0磁道1扇区(512字节)
前446字节代表主引导记录,后64字节代表磁盘分区表(每个分区占16字节,这就是为什么linux系统主分区+扩展分区只能有四个的原因),最后2字节为分区结束标识
磁盘分区表的16字节都代表什么
1 bytes 分区状态 1bytes 起始磁头号 2bytes 分区起始扇区和柱面号 1bytes 分区类型
1 bytes 结束磁头号 2bytes 分区结束扇区和柱面号 4bytes 线性寻址 4bytes 分区大小
磁盘分区:
fdisk 适合小于2T的磁盘分区 --fdisk /dev/sdb
分区结束后 partprode /dev/sdb 告诉系统内核修改了分区
parted适合大于2T的磁盘分区,也可以对小于2T的磁盘进行分区
parted /dev/sdb mklabel gpt parted /dev/sdb mkpart 0 2048000
磁盘分区知识:
分区实质:修改分区表,划分起始柱面号和扇区号
一块磁盘分区:最多4p,3p+e,2p+e,1p+e,1p,2p,3p p主分区 e扩展分区 l逻辑分区
最多有一个扩展分区,操作系统的限制,扩展分区不能直接用,必须划分逻辑分区
fdisk 分区的原理,就是修改64位字节分区表。不能对大于2T的磁盘分区
parted GNU分区工具,可以适合各种分区情况,当然也支持大于2T分区
生产分区的建议:
常规分区:web集群节点
/boot 100-200M
swap 内存1.5(内存大于8G,就只分8-16G)
/ 80-200G
/data 数据分区
门户网站:灵活分区
/boot 100-200M
swap 内存1.5(内存大于8G,就只分8-16G)
/ 80-200G
剩余分区不分,留着,将来领用的部分自己再分
文件系统小结:
1.文件系统:文件系统是对一个存储设备上的数据和源数据进行组织的一种机制,常见文件系统如ext2,ext3,ext4,NTFS或FAT,FAT32
2.分区必须格式化创建文件系统才能存放数据(所以必须格式化),不同分区只能有一种文件系统
3.
Linux下常见的文件系统ext2,ext3,ext4,zfs,xfs和Reiserfs
文件系统的选型
1)SAS/SATA硬盘文件系统选择
a.reiserfs 大量小文件业务首选 reiserfs
b.xfs 数据库MYSQL业务,门户案例
c.ext4 视频下载,流媒体,
Centos默认的文件系统,都是很优秀的
文件系统介绍:
磁盘分区之后,必须格式化,划分文件系统,才能进行数据的存放
文件系统类型:ext2(没有日志功能),ext3(有日志功能可以通过日志文件恢复丢失的文件),
ext4(Centos 6 默认的文件系统),xfs(Centos 7 默认的文件系统),reiserfs(大量小文件的首选)
选择文件系统的关键:维护成本,性能,可靠,综合权衡
选择文件系统的好与坏不是很重要,重要的在于你的前端有多少缓存,能帮磁盘挡住数据
前端缓存:CDN--->内部web cache-->数据库和存储cache--->最后到磁盘(数据库和存储)
Linux磁盘设备基础的更多相关文章
- 12、Linux磁盘设备基础知识(2)
12.4.计算磁盘容量: 磁盘的大小=盘面大小*磁头数 盘面的大小=磁道大小*磁道数 磁道大小=512字节*扇区数 磁盘的大小=512字节*扇区数*磁道数*磁头数 磁盘的大小=柱面大小*柱面数 柱面大 ...
- 12、Linux磁盘设备基础知识(1)
GB TB PB EP ZB YB BB:
- linux磁盘分区模式
linux磁盘分区模式 模式一:MBR 1)主分区不超过四个 2)单个分区容量最大2TB 模式二:GPT 1)主分区个数"几乎"没有限制(原因:在GPT的分区表中最多可以支持128 ...
- MySQL 调优基础(四) Linux 磁盘IO
1. IO处理过程 磁盘IO经常会成为系统的一个瓶颈,特别是对于运行数据库的系统而言.数据从磁盘读取到内存,在到CPU缓存和寄存器,然后进行处理,最后写回磁盘,中间要经过很多的过程,下图是一个以wri ...
- <实训|第七天>横扫Linux磁盘分区、软件安装障碍附制作软件仓库
期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...
- 调整Linux磁盘分区的大小的方法
昨天数据入库时,一直报错,说磁盘满了,,df -h 一看,发现/目录下只有50G空间,已使用49G:我的程序和dbss都安装在/目录下,ftp到的数据放在/data下的一个子目录下,分解完的 ...
- Linux 磁盘管理
Linux磁盘管理好坏管理直接关系到整个系统的性能问题. Linux磁盘管理常用三个命令为df.du和fdisk. df:列出文件系统的整体磁盘使用量 du:检查磁盘空间使用量 fdisk:用于磁盘分 ...
- Linux磁盘、目录、文件操作命令
0x01. Linux磁盘分区与目录结构 ① 主分区.拓展分区.逻辑分区:早期主引导扇区MBR用64B存放主分区信息,每个分区用16B,因而上限为4个主分区,后来,因分区需求,引入拓展分区(类主分区) ...
- Linux磁盘分区与格式化
磁盘分区格式说明 linux分区不同于windows linux下分区标示: 例如:hda1 hd这两个字母表示分区所在的设备类型,hd标示IDE类型硬盘,sd表示SCSI类型硬盘 第三字母a标示硬盘 ...
随机推荐
- LSTM代码
tensorflow的关于LSTM的代码,经过反复的调试和修改,终于运行成功了,可以把训练过程的结果保存起来,然后预测的时候直接取出来.花了很长时间才把官网上的代码调试成功,里面的坑有很多需要填补,还 ...
- 矩阵的五种分解的matlab实现
由于这学期修了矩阵分析这门课,课程要求用matlab实现矩阵的5种分解,仅仅是实现了分解,上传到博客存档,万一哪天某位同学就需要了呢.. 1.矩阵的满秩分解 代码实现 %矩阵的满秩分解 clear % ...
- vlc for mac设置中文的方法
VLC for mac是一款mac系统下的多媒体播放器,支持播放MPEG-1.MPEG-2.MPEG-4.DivX.MP3和OGG,以及DVD.VCD.等各种流媒体协议在内的多种协议格式,并且能够对电 ...
- linux 去掉 ^M 的方法
在linux上经常遇到这种问题,从网上下载文件到 linux 上后,就多了很多 ^M这种东西,如何集体删除这种东西呢! 用 vim 打开文件 进行如下设置 将文件格式转化为unix :set ff= ...
- HDU 6212 Zuma
Zuma 这个题没有素质!它卡常! 我发现网上很多人的题解都写得很奇怪,也不好确定正确性,所以我借这篇题解表达一下愚见 定义$ dp[i][j][0...4]$表示 0:消完了 1:还剩1个0 2:还 ...
- k8s相关
卸载kubernetes-dashboard kubectl get secret,sa,role,rolebinding,services,deployments --namespace=kube- ...
- ([Ljava/lang/String;)V的含义
https://blog.csdn.net/longaiyunlay/article/details/80049440 “([Ljava/lang/String;)V” 它是一种对函数返回值和参数的编 ...
- 【Node.js】Node.js的调试
目录结构: contents structure [-] 使用console.log() 使用Chrome DevTools 使用Visual Studio Code 与JavaScript运行在浏览 ...
- Could not find com.android.tools.build:gradle:3.3.0.
导入新项目时报错: Error:Could not find com.android.tools.build:gradle:3.3.0. Searched in the following locat ...
- Sword 哈希表
哈希表 哈希表是一种典型的以空间换取时间的数据结构,在没有冲突的情况下,对任意元素的插入.索引.删除的时间复杂度都是O().这样优秀的时间复杂度是通过将元素的key值以hash方法f映射到哈希表中的某 ...