进程管理

linux维护工作中,常常需要对系统上运行的程序进行管理,那么进程管理就显得相当重要。

进程初识

  • 什么是进程?

      进程是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念。它代表CPU所能处理的单个任务。
  • 什么是线程?

      线程是程序流执行的最小单元,可以理解为进程中执行的一段程序片段。
  • 进程与线程联系和区别

      一个线程可撤销另一个线程,同一个进程中的多个线程可并发执行。
      可与同进程中的其他线程共享内存空间,拥有自己的栈空间,和独立的执行序列。
  • 进程分类

      守护进程:在系统引导过程中启动的进程,和终端无关。
      前台进程:跟终端相关,通过终端启动的进程。
      两者可相互转化。
  • 进程优先级
      1-99:实时优先级:数字越大,优先级越高。
      100-139:静态优先级:数字越小,优先级越高。
      nice值:-20,193、ps命令 用于报告系统当前系统进程状态。

  • 进程状态
    进程管理

运行态:
  当进程正在被CPU执行,或已经准备就绪随时可有调度程序执行,则该进程处于运行态(running).当系统资源已经可用时,进程就被唤醒而准备进入准备运行状态,该状态为就绪态。
可中断睡眠状态:
  处于这个状态的进程不会被系统调度。当系统产生了一个中断或者释放了进程正在等待 的资源,或者收到一个信号,都可以唤醒进程转换到就绪态(运行态)。
不可中断睡眠转态:与可中断睡眠转态类似。但只能被wake_up()函数唤醒才能转换为就绪态。
暂停转态:
  进程收到信号SIGSTOP、SIGTSTP、SIGTTIN或SIGTTOU时会转换为暂停转态,向其发送SIGCONT信号可让其转换为可运行状态。
僵尸状态:
  当进程已经停止运行,但其父进程还没有询问其状态时,该进程处于僵死状态。

进程管理命令

  • ps命令
    用于报告当前系统的进程状态。可以搭配kill指令随时中断、删除不必要的程序。ps命令是最基本同时也是非常强大的进程查看命令,使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。
    进程管理

  • top命令
    top命令可以实时动态地查看系统的整体运行情况,是一个综合了多方信息监测系统性能和运行信息的实用工具。通过top命令所提供的互动式界面,用热键可以管理。
    进程管理

  • htop命令
    htop是Linux系统下一个基本文本模式的、交互式的进程查看器,主要用于控制台或shell中,可以替代top,或者说是top的高级版。

      快速查看关键性能统计数据,如CPU(多核布局)、内存/交换使用
      可以横向或纵向滚动浏览进程列表,以查看所有的进程和完整的命令行
      杀掉进程时可以直接选择而不需要输入进程号
      通过鼠标操作条目
      比top启动得更快

    进程管理

  • vmstat命令
    显示虚拟内存状态(Viryual Memor Statics),但是它可以报告关于进程、内存、I/O等系统整体运行状态。
    进程管理

  • pmap命令
    pmap命令用于报告进程的内存映射关系,是linux调试及运维的一个很好的工具。
    pmap [options] pid [...]
    -x 显示详细格式
    pmap 读取的是/proc/PID/maps中的信息。

  • glances命令
    Glances 是一个由Python编写,使用 psutil 库来从系统抓取信息的基于curses开发的跨平台命令行系统监视工具。通过Glances,可以监视CPU,平均负载,内存,网络流量,磁盘 I/O,其他处理器和文件系统空间的利用情况。
    进程管理

  • dstat命令
    dstat命令是一个全能信息统计工具,拥有彩色界面,支持实时刷新,功能非常强大。
    进程管理

  • kill命令
    kill命令可以给进程发送信号,通过传递信号可以完成多种操作

      常用信号
      1) SIGHUP: 无须关闭进程而让其重读配置文件;
      2) SIGINT: 中止正在运行的进程;相当于Ctrl+c;
      9) SIGKILL: 杀死正在运行的进程;
      15) SIGTERM:终止正在运行的进程;
      18) SIGCONT:
      19) SIGSTOP:
      显示当前可用信号 kill -l

    例:[root@localhost ~]# kill -9 4197
      Killed
      [root@localhost ~]#

  • pkill命令
    pkill命令可以按照进程名杀死进程。pkill和killall应用方法差不多,也是直接杀死运行中的程序;如果想杀掉单个进程,请用kill来杀掉。
    进程管理

原创文章,作者:M20-1--孔祥文,如若转载,请注明出处:http://www.178linux.com/44411

(0)
上一篇 2016-09-07 17:17
下一篇 2016-09-07 17:44

相关推荐

  • N25-第6周博客作业

    N25-第6周博客作业 vim:     模式化的编辑器         基本模式:             编辑模式,…

    Linux干货 2017-01-09
  • Ansible的基础知识

    为什么要学习ansible:     ansible是自动化运维的一种工具,使用ansible可以一次性管理多台主机,为多台主机安装或这执行相同或者不同的操作,省去了一台台主机去重复执行相同的任务,可以使用corn选项结合本机的crontab设置本主机的任务性计划,比如,每天导出nginx的access.log和err…

    Linux干货 2016-11-03
  • 马哥教育网络班22期+第2周课程练习 忍者乱太郎喻成

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示?  type 查看文件类型的命令    type /dev/sda     mkdir 创建文件夹     mkdir [ -p -v…

    Linux干货 2016-09-06
  • 心清冷其若冰,志皎洁其若云

    第一篇,当做测试也做开始。 心清冷其若冰,志皎洁其若云。 这闹哄哄的人间啊,仿佛是一堆杂货。无奇不有,无所不能。情感,城市,人际。每天走在这杂乱里,需要有一颗清澈而安静的心,来面对。 会累的。就算是拥有了许多,也是会累的。偶尔,我们也会在深夜里泪流满面吧。偶尔,我们也会心烦意乱的不知所措吧。 太多欲望的人间,热闹的上演着各种剧本。太多空洞的灵魂,喧嚣着各种声…

    Linux干货 2016-11-28
  • LVS详解及拓扑具体实现

    LVS:Linux Virtual Server Linux Cluster:集群,为解决某个特定问题将多台主机组织起来,满足同一个需求; 单台主机处理能力有限,包括cpu、IO、内存、带宽等资源,无法满足客户端请求;把用户的请求分散到多个不同的服务器,分摊压力; 集群的类型: LB:Load Balancing,负载均衡集群;负载均衡器,或调度器、分发器;…

    Linux干货 2016-10-28
  • centos查看和修改文件权限

      查看权限在终端输入:  ls -l xxx.xxx (xxx.xxx是文件名)那么就会出现相类似的信息,主要都是这些:-rw-r–r–其中: 最前面那个 – 代表的是文件类型中间那三个 rw- 代表的是所有者(user)然后那三个 r– 代表的是组群(group)最后那三个 r–   …

    2017-11-26

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-10 11:01

    文档功底相当不错,尤其是思维导图,做的太精美的,赞一个!!!