• linux下查看内存使用情况


    基本内存术语解读

    1> free -m

      同样是做为缓存,buffers和cache又有啥区别呢?

      于是又查了些资料,发现buffers实际应该是叫“缓冲”,其英文解释是:A buffer is something that has yet to be "written" to disk.

      就是说,buffers是将要写入硬盘中的数据缓存。

      而cache的英文解释:A cache is something that has been "read" from the disk and stored for later use.

      就是说,cache是从硬盘或者存储设备读进计算机后缓存在内存中的数据。

      想起看《计算机组成原理》的时候,有看到因特尔的cpu与内存之间有cache,这之间好像有什么区别的样子。

      继续查资料,发现了page cache 和 buffer cache。简单说来,page cache用来缓存文件数据,buffer cache用来缓存磁盘数据。在有文件系统的情况下,对文件操作,那么数据会缓存到page cache,如果直接采用dd等工具对磁盘进行读写,那么数据会缓存到buffer cache。 

      对于cache和buffer,cached是cpu与内存间的,buffer是内存与磁盘间的,都是为了解决速度不对等的问题。

      在free中,buffer 是buffer cache的内存,是块设备的读写缓冲区;cache是page cache的内存, 文件系统的cache。

      关于buffer与chche,这里就不多说了,最后的链接5里讲得挺清楚了。

      这里还有一个名词,Swap,即虚拟内存。当物理内存不够用的时候,就要释放掉一部分空间,以供当前运行程序使用。这些被释放掉的内存的数据就被临时保存在虚拟内存中。但是,并非所有的数据都全被保存,只有那些使用malloc或new生成的对象,他们在文件中并没有相应的“储备”文件,被称为匿名内存数据,需要临时地存进Swap。故Swap又称匿名数据交换空间。在链接3中有其说明。

    2> top

    动态查看系统的资源使用情况

    3> vmstat -  Report virtual memory statistics

    查看虚拟内存使用情况

    参数解读:

    r The number of processes waiting for run time.   处于运行队列中的内核线程数目(进程数)。
    b The number of processes in uninterruptible sleep. 置于等待队列(等待资源、等待输入/输出)的内核线程数目。 处于block队列中不可中断的进程数
    swpd the amount of virtual memory used.  可用的虚拟交换内存
    free the amount of idle memory. 空闲内存
    buff the amount of memory used as buffers. 已用缓冲数目
    cache the amount of memory used as cache. 已用缓存数目
    si Amount of memory swapped in from disk (/s). ���磁盘到内存的交换页数目 (单位/S)
    so Amount of memory swapped to disk (/s). 从交换内存到磁盘的交换页数目(单位/S)
    bi Blocks received from a block device (blocks/s). 接收到块设备的块数(块/秒)
    bo Blocks sent to a block device (blocks/s). 发送到块设备的块数(块/秒)
    in The number of interrupts per second, including the clock. 每秒中断数,包括时钟中断
    cs The number of context switches per second. 每秒上下文切换数
    us Time spent running non-kernel code. (user time, including nice time) 用户时间,处于用户模式的时间百分比
    sy Time spent running kernel code. (system time) 系统时间,处于内核模式的时间百分比
    id Time spent idle. Prior to Linux 2.5.41, this includes IO-wait time. CPU空闲时间,空闲时间百分比
    wa Time spent waiting for IO. Prior to Linux 2.5.41, included in idle. CPU 空闲时间,在此期间系统有未完成的磁盘/NFS I/O 请求
    wt Time stolen from a virtual machine. Prior to Linux 2.6.11, unknown.
  • 相关阅读:
    What the key facts to choose Row Store and Column Store 沧海
    自定义数据源(ECC>BW) 沧海
    What is SAP HANA appliance software 沧海
    安装BI_CONT时遇到Open Data Extraction Requests的问题 沧海
    Process Chain\DTP\Infopackage相关的几个table和function module 沧海
    Note 741478 FAQ: Materialized views 沧海
    HANA 与 Exalytics 的对比 沧海
    SAP HANA database and how to improve performance 沧海
    SAP HANA 已实施的客户清单 沧海
    BW BEx的VBA开发接口介绍 沧海
  • 原文地址:https://www.cnblogs.com/noxy/p/9358329.html
Copyright © 2020-2023  润新知