http://note.sdo.com/u/seeeyou/n/y8Wvx~jT5gpywE00Q000iR
内存
1.2.1
内存基础
通常包含物理内存和虚拟内存(virtual Memory
),好处是通过物理内存(RAM)
和部分硬盘空间(SWAP
)组合增大了总体的内存空间,坏处是由于硬盘部分的虚拟内存的性能有限,并且RAM
和SWAP
之间交换增加了系统的负担。
1.
[phoenix.lif@aliadmin036158 ~]$ free
2.
total used free shared buffers cached
3.
Mem:
7680000
7504764
175236
0
490772
3193856
4.
-/+ buffers/cache:
3820136
3859864
5.
Swap:
2096472
88
2096384
其中,Mem
:
(1) Total
为总的物理内存;
(2) Used
表示总计分配给缓存使用的数量(即buffers
和cache
,但可能部分还未实际使用);
(3)Free
表示未被分配的内存;
(4)share
表示共享内存,一般不会使用;
(5)buffers
:表示系统分配但未被使用的buffers
数量;
(6)Cached
:表示系统分配但未被使用的cache
数量。后面详细说明buffer
和cache
的区别。
-/+ buffers/cache:
(1)Used
表示实际使用的buffers
和cache
总量,即实际使用内存总量;
(2)Free
未被使用的buffer
,cache
及未被分配的内存之和,即系统可用内存。
Swap:
虚拟内存。如果系统物理内存用完了,但是仍有虚拟内存系统仍然可以运行虽然运行很慢;但是如果Swap
也用完了,系统就会发生错误,通常会出现"application
is out of memory"
的错误,严重时造成系统死锁。通常Swap
空间分配为物理内存的2-2.5
倍,但也不用完全按照这个标准,如确定内存完全够用也没必要分配太多,我们线上的服务器就没有分配太多的Swap
空间。
tips:
实际可用内存:Free(-/+ buffers/cache) = Free(Mem)+buffers(Mem)+Cached(Mem);
已分配内存:Used(Mem) = Used(-/+ buffers/cache)+ buffers(Mem) + Cached(Mem)
物理内存总大小:total
(Mem
) = used(-/+ buffers/cache) + free(-/+ buffers/cache)
1.2.2 Buffers & Cache
在 Linux
的实现中,文件 Cache
分为两个层面,一是 Page Cache
,另一个 Buffer Cache
,每一个 Page Cache
包含若干 Buffer Cache
。内存管理系统和 VFS
只与 Page Cache
交互,内存管理系统负责维护每项 Page Cache
的分配和回收。buffer cache
是块设备的读写缓冲区,更靠近存储设备,或者直接就是disk
的缓冲区。
磁盘操作有逻辑级(文件系统)和物理级(磁盘块),这两种缓存分别是缓存逻辑和物理级数据的。如我们进行的是文件系统操作,那么文件被缓存到Page Cache
,如需要刷新文件的时候,Page Cache
将交给Buffer Cache
去完成,因为Buffer
Cache
是缓存磁盘块的。即直接去操作文件就是使用Page Cache
,用dd
等命令直接操作磁盘块,就是buffer cache
缓存。
分享到:
相关推荐
### Linux内存IO培训知识点概述 #### 一、Linux内存管理基础 ##### 1.1 Linux的内核空间&用户空间 - **概念介绍**:在Linux操作系统中,进程的4GB地址空间被划分为两大部分——用户空间和内核空间。这种划分的主要...
总之,Linux下的IO口驱动涉及硬件接口抽象、内存映射、权限管理等多个方面。通过理解这些机制,开发者可以有效地控制硬件设备,实现各种功能。在实际项目中,正确、安全地操作IO口是确保系统稳定运行的关键。
linux系统cpu、内存、IO等监控脚本 可以用作定时任务执行监控
### 实例解析Linux的IO编程 #### Linux标准IO与文件IO概述 在深入探讨Linux的IO编程之前,我们需要先理解Linux中的两种基本IO概念:标准IO(Standard I/O)和文件IO(File I/O)。这两种IO机制在Linux系统中扮演着...
综上所述,Linux下的RapidIO子系统分析与实现是一个涉及硬件抽象、协议解析、设备驱动开发等多个方面的复杂过程。理解和掌握这些知识对于开发高效、可靠的嵌入式系统至关重要,特别是在需要高速通信和低延迟的场景下...
在Linux操作系统中,内核与硬件设备交互是通过设备驱动程序实现的,而访问外设的输入/输出(I/O)内存...通过理解这些概念和技术,开发者可以更好地编写设备驱动,优化系统性能,确保硬件设备在Linux环境下的稳定运行。
Linux 中查看 IO 相关命令 Linux 操作系统中,查看 IO 状态的命令非常重要,特别是在服务器出现异常情况时。以下是查看 Linux 服务器硬盘 IO 访问负荷的方法: 1. 使用 Top 命令 Top 命令可以显示当前系统的实时...
`abu-1.0`是一个专为Linux设计的I/O读写工具,旨在提供类似`ru`和`adu`的功能,以辅助程序员进行更便捷的调试和性能分析。 `ru`(run time)和`adu`(average disk utilization)是经典的Linux系统监控工具。`ru`...
在Linux系统中,输入/输出(IO)数据通道的处理是一个复杂的过程,涉及到多个层次的协作与交互。了解这些层次及其工作原理对于深入理解Linux系统的IO机制至关重要。 1. **用户空间层**:应用程序通过标准的系统调用...
嵌入式开发板通常运行的是Linux操作系统,而且很多嵌入式系统都会有存储介质(如SD卡、eMMC等),因此可以使用标准的Linux IO函数进行操作。当把编译好的程序下载到嵌入式开发板上时,同样可以执行标准的字符型操作...
本文旨在全面、深入地探讨 Linux 文件 I/O 的各个方面,并尝试用通俗易懂的方式阐述这些概念,以帮助读者更好地理解如何优化和提高文件 I/O 性能。 #### 二、文件 I/O 的层次结构 Linux 文件 I/O 设计采用了分层...
几乎每一种外设都是通过读写设备上的寄存器来进行...CPU对外设IO端口物理地址的编址方式有两种:一种是I/O映射方式(I/O-mapped),另一种是内存映射方式(Memory-mapped)。而具体采用哪一种则取决于CPU的体系结构。
在Linux操作系统中,标准输入/输出(Standard Input/Output,简称标准IO)是系统提供的一种基本I/O模型,用于程序与外部设备之间的数据传输。在这个案例中,我们关注的是如何利用标准IO进行学生信息的管理。`ls_stu....
本文将深入探讨"Linux下IO口驱动(2)"的主题,主要关注如何实现对IO口的控制,使其能自由地输出任意电平。 一、Linux I/O模型 在Linux系统中,I/O操作有多种模型,包括同步I/O、异步I/O(AIO)、中断驱动I/O、DMA...
【基于Linux的RapidIO技术】深入解析 RapidIO是一种高速互连技术,最初由摩托罗拉(现飞思卡尔半导体)开发,主要用于嵌入式系统,特别是电信级设备,如4G LTE的eNodeB设备。RapidIO提供了一个基于消息的接口,能够...
Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...
### Linux文件IO操作详解 #### 基本概念 Linux 文件 I/O 操作是学习 Linux 应用开发的基础,尤其对于初学者来说至关重要。本文旨在详细介绍 Linux 下的文件 I/O 操作及其相关概念。 #### 文件 在 Linux 系统中,...
标题中的"GPIO.rar_GPIO_GPIO linux_Linux IO_io_linux gpio"表明这是一个关于Linux GPIO驱动程序的资源包,主要涉及Linux系统下的GPIO读写操作。 在Linux中,GPIO的操作通常需要通过内核驱动来实现。Linux提供了...
linux为了支持多个硬件体系,在IO访问上做了自己的接口。可以通过IO内存和IO端口这两种方式进行IO访问