内核的功用:进程管理、文件系统、网络功能、内存管理、驱动程序、安全功能

Process:运行中的程序的一个副本。

  存在生命周期

Linux内核存储进程信息的固定格式 :task struct

  多个任务的task struct组件的链表:task list

进程创建:

  init

    父子关系

    进程:都由其父进程创建

      fork(),clone()

  进程优先级:

    0-139:

      1-99:实时优先级;

        数字越大,优先级越高;

      100-139:静态优先级;

        数字越小,优先级越高;

      Nice值:

        -20,19

    Big O

      O(1),O(logn),O(n),O(n^2),O(2^n)

  进程内存:

    Page Frame:页框,用存储页面数据

      存储Page

      MMU:memory Management Unit

  IPC:Inter Process Communication

    同一主机上:

      signal

      shm:shared memory

      semerphor

    不同主机上:

      rpc:remote procesure call    远程过程调用

      socket:

Linux内核:抢占式多任务

  进程类型:

    守护进程:daemon,在系统引导过程中启动的进程,跟终端无关的进程;

    前台进程:跟终端相关,通过终端启动的进程

      注意:也可以把在前台启动的进程送往后台,以守护模式运行;

  进程状态:

    运行态:running

    就绪态:ready

    睡眠态:

      可中断:interruptable

      不可中断:uninterruptable

    停止态:暂时于内存中,但不会被调度,除非手动启动之:stopped

    僵死态:zombie

  进程的分类:

    CPU-Bound

    IO-Bound

  《Linux内核设计与实现》,《深入理解Linux内核》,

Linux进程查看及管理的工具:pstree,ps,pidof,pgrep,top,htop,glance,pmap,vmstat,dstat,kill,pkill,job,bg,fg,nohup

  pstree命令:

    pstree - display a tree of processes

  ps:process state

    ps - report a snapshot of the current processes

    Linux系统各进程的相关信息均保存在/pro/PID目录下的各文件中;

    ps [OPTION]...

      选项:支持两种风格

      常用组合:aux

        u:以用户为中心组织进程状态信息显示

        a:与终端相关的进程;

        x:与终端无关的进程;

        ~]# ps aux

        USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND

        进程属主   进程ID  占据CPU时间百分比   占据内存空间百分比  虚拟内存大小

        VSZ:Virtual memory SiZe

        RSS:ReSident Size,常驻内存集

        TTY:从哪个终端启动的,?代表与终端无关

        STAT:进程状态

          R:running

          S:interruptable sleeping

          D:uninterruptable sleeping

          T:stopped

          Z:zombie

          +:前台进程

          l:多线程进程

          N:低优先级进程

          <:高优先级进程

          s:session leader

          TIME:运行占据CPU的累计时长

          COMMAND:由什么命令启动的相关进程

      常用组合:-ef

        -e:显示所有进程

        -f:显示完整格式程序信息

      常用组合:-eFH

        -F:显示完整格式的进程信息

        -H:以进程层级格式显示进程相关信息

      常用组合:-eo,axo

        -eo pid,tid,class,rtprio,ni,pri,psr,pcpu,stat,comm

        axo stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,pcpu,comm

          ni:nice值

          pri:priority,优先级

          psr:processor,CPU

          rtprio:实时优先级

  pgrep,pkill

    pgrep [OPTION] pattern

    pkill [OPTION] pattern

      -u uid:effective user

      -U uid:real user

      -t terminal:与指定终端相关的进程

      -l:显示进程名

      -a:显示完整格式的进程名

      -P pid:显示其父进程为此处指定的进程的进程列表

  pidof:根据进程名获取其PID;

  top:

    有许多内置命令:

      排序:

        P:以占据的CPU百分比;

        M:占据内存百分比;

        T:累积占据CPU时长;

      首部信息显示:

        uptime信息:l 命令

        tasks及cpu信息:t命令

          cpu分别显示:1(数字)

        memory信息:m命令

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

           用户空间  内核空间  nice值  空间时间  等待时间  硬中断时间  软中断时间  被偷走的时间       【各自时间所占据的比例】

      退出命令:q

      修改刷新时间间隔:s

      终止指定进程:k

    选项:

      -d #:指定刷新时间间隔,默认为3秒

      -b:以批次方式

      -n #:显示多少批次;

  htop命令:

    选项:

      -d #:指定延迟时间;

      -u UserName:仅显示指定用户的进程;

      -s COLOMN:以指定字段进行排序;

    命令:

      s:跟踪选定进程的系统调用;

      l:显示选定进程打开的文件列表;

      a:将选定的进程绑定至某指定CPU核心;

      t:显示进程树

    注意:Fedora-EPEL源

Linux:Day12(上) 进程的更多相关文章

  1. 深入Linux内核架构——进程管理和调度(上)

    如果系统只有一个处理器,那么给定时刻只有一个程序可以运行.在多处理器系统中,真正并行运行的进程数目取决于物理CPU的数目.内核和处理器建立了多任务的错觉,是通过以很短的间隔在系统运行的应用程序之间不停 ...

  2. NoSql1 在Linux(CentOS)上安装memcached及使用

    前言:       今天是初五,生活基本要从过年的节奏中回归到正常的生活了,所以想想也该想想与工作有关的事情了.我之前在工作中会经常使用memcached和redis,但是自己一直没有时间系统的好好看 ...

  3. Linux服务器上监控网络带宽的18个常用命令

    [51CTO精选译文]本文介绍了一些可以用来监控网络使用情况的Linux命令行工具.这些工具可以监控通过网络接口传输的数据,并测量目前哪些数据所传输的速度.入站流量和出站流量分开来显示. 一些命令可以 ...

  4. Linux如何查看进程、杀死进程、启动进程等常用命令

    Linux如何查看进程.杀死进程.启动进程等常用命令 关键字: linux 查进程.杀进程.起进程1.查进程    ps命令查找与进程相关的PID号:    ps a 显示现行终端机下的所有程序,包括 ...

  5. Linux 服务器的网络配置 - 2. 查看 Linux 服务器的进程

    2. 查看 Linux 服务器的进程 1)ps [主要选项] -a  显示系统中所有进程的信息 -e  显示所有进程的信息 -f  显示进行的所有信息 -l   以长格式显示进程信息 -r  只显示正 ...

  6. Linux 线程与进程,以及通信

    http://blog.chinaunix.net/uid-25324849-id-3110075.html 部分转自:http://blog.chinaunix.net/uid-20620288-i ...

  7. Linux系统编程@进程通信(一)

    进程间通信概述 需要进程通信的原因: 数据传输 资源共享 通知事件 进程控制 Linux进程间通信(IPC)发展由来 Unix进程间通信 基于System V进程间通信(System V:UNIX系统 ...

  8. Linux服务器上监控网络带宽的18个常用命令(转)

    本文介绍了一些可以用来监控网络使用情况的Linux命令行工具.这些工具可以监控通过网络接口传输的数据,并测量目前哪些数据所传输的速度.入站流量和出站流量分开来显示. 一些命令可以显示单个进程所使用的带 ...

  9. [转]Linux Ubuntu上架设FTP

    Linux Ubuntu上架设FTP http://www.blogjava.net/stonestyle/articles/369104.html 操作系统:ubuntu (GNU/Linux) 为 ...

随机推荐

  1. 《深入java虚拟机》读书笔记之垃圾收集器与内存分配策略

    前言 该读书笔记用于记录在学习<深入理解Java虚拟机--JVM高级特性与最佳实践>一书中的一些重要知识点,对其中的部分内容进行归纳,或者是对其中不明白的地方做一些注释.主要是方便之后进行 ...

  2. Linux基础知识第一讲,基本目录结构与基本命令

    目录 一丶Window 与 Linux的目录结构 1.Windows 与 Linux目录简介 2.Linux目录主要作用 3.任务栏与菜单栏,与关闭按钮 二丶Linux终端与常见命令学习 1.终端中的 ...

  3. Spring Boot 系列总目录

    一.Spring Boot 系列诞生原因 上学那会主要学的是 Java 和 .Net 两种语言,当时对于语言分类这事儿没什么概念,恰好在2009年毕业那会阴差阳错的先找到了 .Net 的工作,此后就开 ...

  4. 大数据利器Hive

    序言:在大数据领域存在一个现象,那就是组件繁多,粗略估计一下轻松超过20种.如果你是初学者,瞬间就会蒙圈,不知道力往哪里使.那么,为什么会出现这种现象呢?在本文的开头笔者就简单的阐述一下这种现象出现的 ...

  5. windows7安装MySQL-python遇到的坑

    最近在windows环境上搭建flask使用环境,遇到过很多坑,这次就记录下安装flask-mysqldb所遇到的坑. 正常逻辑是使用pip install flask-mysqldb进行安装.但是会 ...

  6. ssh转发代理:ssh-agent用法详解

    SSH系列文章: SSH基础:SSH和SSH服务 SSH转发代理:ssh-agent用法详解 SSH隧道:端口转发功能详解 使用ssh-agent之前 使用ssh公钥认证的方式可以免去ssh客户端(如 ...

  7. Mysql中的WITH ROLLUP用法

    1.WITH ROLLUP:在group分组字段的基础上再进行统计数据. 例子:首先在name字段上进行分组,然后在分组的基础上进行某些字段统计,表结构如下: CREATE TABLE `test` ...

  8. Win10系统给文件夹添加备注

    在Win10系统中,相信大多用户都没有看到过文件或者是文件夹上有备注信息.下面给大家分享下在Win10系统中给文件夹或文件添加备注的方法.在添加备注之前,首先我们要在需要显示备注的文件夹中显示&quo ...

  9. Java学习笔记之——TreeMap

    TreeMap: 特点:存储时,按照键排序 底层使用一个红黑树,特殊的而二叉树 排序跟comparable,comparator有关系 如果需要在添加时进行排序,使用hashMap即可 构造方法: T ...

  10. JAVA-HashMap实现原理

    一.HashMap实现原理 1. HashMap概述 HashMap是基于哈希表的Map接口的非同步实现.它允许存入null值和null键.它不保证存入元素的顺序与操作顺序一致,主要是不保证元素的顺序 ...