古黑论
登陆 / 注册 搜索

USERCENTER

站内搜索引擎

打印 上一主题 下一主题

[Linux] 零基础Linux|第十六课_系统负载和进程管理

[复制链接]
跳转到指定楼层
楼主
小执念论坛大牛 发表于 2018-6-18 22:58:44 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
        查看系统负载可以通过“w”和“top”命令来查看。

 1-w命令.png 零基础Linux|第十六课_系统负载和进程管理

        一、”w“命令

        USER:登录用户名
        TTY:登录后系统分配的终端号
        FROM:远程主机名,即从哪里登录的
        [email protected]:何时登录
       
        IDLE:用户空闲时间。这是个计时器,一旦用户执行任何操作,该计时器便会被重置
        JCPU:和该终端连接的所有进程占用时间。包括当前正在运行的后台作业占用时间
        PCPU:当前进程所占用时间
        WHAT:当前正在运行进程的命令行

        二、“top”命令

       咋一看有种眼花缭乱的感觉。我们这篇文章只讲简单的,不去深入研究,不然这篇文章就太长了。。。。

 2-top命令.png 零基础Linux|第十六课_系统负载和进程管理

        load average :0.72, 0.20, 0.11

        这是意思是,这个机器在1分钟、5分钟、15分钟中的CPU使用情况,0.72可以理解为使用了72%(这是对单核CPU而言,如果是双核CPU,要达到两个CPU使用率为100%,上面的数字应该是2)

        Tasks: 358 total,   2 running, 356 sleeping,   0 stopped,   0 zombie

        这个意思是,系统现在共有358个进程,其中有2个正在运行,356个正在休眠,0个停止,0个僵尸进程。

        %Cpu(s):0.0 us, 0.3 sy, 0.0 ni, 99.7 id, 0.0 wa, 0.0 hi, 0.0si, 0.0 st

        这里显示不同模式下所占cpu时间百分比,这些不同的cpu时间表示:
       
        us, user: 运行(未调整优先级的) 用户进程的CPU时间
        sy,system: 运行内核进程的CPU时间
        ni,niced:运行已调整优先级的用户进程的CPU时间
        id,空闲CPU
        wa,IO wait: 用于等待IO完成的CPU时间
        hi:处理硬件中断的CPU时间
        si: 处理软件中断的CPU时间
        st:这个虚拟机被hypervisor偷去的CPU时间(译注:如果当前处于一个hypervisor下的vm,实际上hypervisor也是要消耗一部分CPU处理时间的)。

        KiB Mem:(物理内存)   1862688 total,  1686940 used,   175748 free,   157204 buffers
        KiB Swap:(交换分区)  4194300 total,    49500 used,  4144800 free.   93278 cached Mem

        total--内存总量(单位为kb)used--使用中的内存free--空闲的内存buffers--缓存使用的内存

        这里要说明的是不能用windows的内存概念理解这些数据,如果按windows的方式此台服务器“危矣”:2GB的内存总量只剩下171MB的可用内存。

        Linux的内存管理有其特殊性,复杂点需要一本书来说明,这里只是简单说点和我们传统概念(windows)的不同。#362:

        第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

       简单来说就是linux会把用过的东西,都存到内存中去,这样不会经常访问磁盘,提高网站响应速度。

        如果出于习惯去计算可用内存数,这里有个近似的计算公式:free + buffers + cached,按这个公式此台服务器的可用内存:

175748+157204+93278=416MB

        对于内存监控,在top里我们要时刻监控swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。

       继续往图下看:

        PID:进程ID,进程的唯一标识符

        USER:进程所有者的实际用户名。

        PR:进程的调度优先级。这个字段的一些值是'rt'。这意味这这些进程运行在实时态。

        NI:进程的nice值(优先级)。越小的值意味着越高的优先级。负值表示高优先级,正值表示低优先级

        VIRT:进程使用的虚拟内存。进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES

        RES:驻留内存大小。驻留内存是任务使用的非交换物理内存大小。进程使用的、未被换出的物理内存大小,单位kb。

        RES=CODE+DATA

        SHR:SHR是进程使用的共享内存。共享内存大小,单位kb

        S:这个是进程的状态。它有以下不同的值:

        D - 不可中断的睡眠态。
        R – 运行态
        S – 睡眠态
        T – 被跟踪或已停止
        Z – 僵尸态
        %CPU:自从上一次更新时到现在任务所使用的CPU时间百分比。

        %MEM:进程使用的可用物理内存百分比。

        TIME+:任务启动后到现在所使用的全部CPU时间,精确到百分之一秒。

        COMMAND:运行进程所使用的命令。进程名称(命令名/命令行)

        还有许多在默认情况下不会显示的输出,它们可以显示进程的页错误、有效组和组ID和其他更多的信息。

        三、进程管理

在top命令中,在COMMAND下方是进程的名称,我们可以通过这个来找出这个进程的PID,从而 kill 掉它。

        例如找 mysqld 的 ps aux |grep mysqld


 3-ps aux.png 零基础Linux|第十六课_系统负载和进程管理

       mysql 的进程 PID 为 27946 ,我们可以直接 kill 27946 ,然后这个 mysql 进程(软件)就被关掉了,不存在像 windows 那样,有通过任务管理器也杀不死的软件。

       强制结束某个进程 ,可以用 kill -9 进程pid


       进程强行被终止,这常会带来一些副作用,如数据丢失或者终端无法恢复到正常状态。


       关于 kill 命令,以后我们有机会在扯扯#373:

上一篇:Mysql为什么搞了一个存储引擎(innodb)的概念?摘要:存储引擎到底是什么?Oracle为什么没有存储引擎?存 ...
下一篇:为什么中国做不出自己的CPU和操作系统?摘要:中国芯片产业在90年代曾经有很好的开局,可惜 ...
回复

使用道具 举报

沙发
 楼主| 小执念论坛大牛 发表于 2018-6-18 23:00:17 | 只看该作者
放一天假,把以前的坑填一下。。

虽然写的很烂
板凳
梦醒 发表于 2018-6-20 23:36:10 来自手机 | 只看该作者
沙发,,,,,

评分

参与人数 1热心值 +6 金币 +6 收起 理由
小执念 + 6 + 6 奖励~

查看全部评分

地板
夏雨初晴 发表于 2018-6-21 14:46:32 | 只看该作者
    撸主。。。你额头有朝天骨。。。 眼里有灵光。。。仙人转世。。。神仙下凡。。。我终于等到你发帖了。。。别动。。。虽然我泄露了天机。。。灾劫难免。。。可这是我命中注定。。。就算我要冒着进小黑屋的危险。。。也要帮你up一下。。。  
5#
暮色里的白雪檐 发表于 2018-6-24 09:11:37 来自手机 | 只看该作者
解释就是掩饰,掩饰就是编故事!
高级模式
B Color Image Link Quote Code Smilies
您需要登录后才可以回帖 登录 | 立即注册  

本版积分规则

关于我们|小黑屋|手机版|Archiver|古黑论

GMT+8, 2019-5-22 17:44 , Processed in 0.196582 second(s), 60 queries .

© 2015-2019 GuHei.Net

Powered by Discuz! X3.4

快速回复 返回列表