进程

简介:
  1. 什么是进程?

          进程是操作系统的概念,每当我们执行一个程序时,对于操作系统来讲就创建了一个进程,在这个过程中,伴随着资源的分配和释放。可以认为进程是一个程序的一次执行过程。      

  2. 进程创建:
    init :第一个进程
    父子关系
    进程:都由其父进程创建,CoW ,fork(), clone()           

  3. 进程优先级:
    系统优先级: 数字越小,优先级越高
    0-139 (CentOS4,5) )
    各有140 个运行队列和过期队列
    0-98 ,99 (CentOS6) )
    实时优先级: 99-0 值最大优先级最高

    nice 值:-20 到19 ,对应系统优先级100-139 或99

    wKiom1m1FuHQgBxMAAE-QX7HhNo907.png

  4. Big O :时间复杂 度 ,用时和规模 的 关系
    O(1), O(logn), O(n) 线性, O(n^2) 抛物线, O(2^n)  

  5. 进程状态
    Linux 内核:抢占式多任务
    进程类型:
    守护进程: daemon, 在系统引导过程中启动的进程, 和 终端无
    关进程
    前台进程:跟终端相关,通过终端启动的进程
    注意:两者可相互转化
    进程状态:
    运行态:running
    就绪态:ready
    睡眠态:
    可中断:interruptable
    不可中断:uninterruptable
    停止态:stopped, 暂停于内存,但不会被调度,除非手动启动
    僵死态:zombie

  6. pstree :查看进程   -p 把子进程都详细地列出来

    wKioL1m1F_XhA32hAACDXiTN0LM459.png    

ps(process state) 进程状态

 ps[OPTION]...支持三种选项:

UNIX 选项 -A -e

BSD 选项  a

GNU 选项  --help

选项:默认显示当前终端中的进程

选项包括所有终端中的进程

选项包括不链接终端的进程

选项显示进程所有者的信息

选项显示进程的父进程

k| --sort 属性 对属性 排序

属性…选项显示定制的信息

pid comm %cpu %mem state tty euser ruser

-C 后可跟脚本和命令


STAT :进程状态

running

S: interruptable sleeping

D: uninterruptable sleeping

T: stopped

Z: zombie

+: 前台进程

l: 多线程进程

:内存 分页并带锁

:低优先级进程

<: 高优先级进程

s: session leader ,会话(子进程)发起者


常用组合:-ef

-e: 显示所有进程

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

常用组合:-eFH

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

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

 常用组合:自定义

-eo pid,tid,class,rtprio,ni,pri,psr,

pcpu,stat,comm

axo stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,

pid,pcpu,comm


nice 调整优先级

 pri: priority 优先级

 psr: processor CPU 编号

 rtprio: 实时优先级

 示例:ps axo pid,cmd,psr,ni,pri,rtprio

renice –n 10 ping 127.17.0.1 指定命令优先级

Renice 修改优先级


pgrep搜索进程信息

Pgrep –lU wang 真正发起者

Pgrep –t pts/0 谁在终端上登陆

Pgrep –a “bash”


pidof按确切的程序名显示pid

Pidof bash 查看正在运行的进程编号

Ps aux |grep httpd 查看某个服务是否运行

Pidof httpd &> /dev/null ||systemctlrestart httpd


Uptime 显示启动状态

当前时间,系统已启动的时间,当前上线人数,系统平均负载(1510分钟的平均负载,一般不会超过1

系统平均负载:在特定时间间隔内运行队列中的平均进程数。

通常每个cpu内核的当前活动进程数不大于3,那么系统的性能良好。如果每个cpu内核的任务数大于5,那么此主机的性能有严重问题

如果linux主机是1个双核cpu,当load average6的时候说明机器已经被充分使用。

 top显示进程使用系统资源情况

wKioL1m1HX-zaqCFAAE49FYtf6w304.png

top :有许多内置命令:

排序

:以占据的CPU 百分比,%CPU

:占据内存百分比,%MEM

:累积占据CPU 时长,TIME+

首部信息显示

uptime 信息:命令

tasks cpu 信息:命令

cpu 分别显示:1 ( 数字)

memory 信息:命令

退出命令:q

修改刷新时间间隔:s

终止指定进程:k

保存文件:W

选项:

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

-b: 全部显示所有进程

-n #: 刷新多少次后退出

栏位信息简介

us :用户空间

sy :内核空间

ni :调整nice 时间

id :空闲

wa :等待IO 时间

hi :硬中断

si :软中断(模式切换)

st :虚拟机偷走的时间


本文转自    honeyorange   51CTO博客,原文链接:http://blog.51cto.com/13172732/1964162

相关文章
|
网络协议 调度 Python
进程小练习
进程小练习
|
5月前
|
存储 安全 Linux
进程与线程(一)进程相关
进程与线程(一)进程相关
34 1
|
8月前
|
Linux API 调度
进程,任务
进程,任务
39 1
|
8月前
|
存储 Java Unix
什么是进程?
什么是进程?
89 0
|
8月前
|
Java Linux API
进程的认识
进程的认识
|
8月前
|
C语言
进程的初步实现
进程的初步实现
104 0
|
存储 C语言 C++
进程与线程
在我们刚开始学C语言程序设计的时候,都是单线程的,实际上我们用的电脑都是多线程的。这里说的多线程包含了并行和并发。
|
存储 算法 程序员
一定要知道的进程知识
一定要知道的进程知识
151 0
一定要知道的进程知识
|
缓存 监控 测试技术
【Linux进程控制】进程创建 | 进程终止 | 进程等待 | 进程替换
本文主要学习理解 fork 的返回值、写时拷贝的工作细节、为什么要存在写时拷贝;进程退出码、进程退出的场景及常见的退出方法、对比 man 2 _exit 和 man 3 exit;进程终止、操作系统怎么进行释放资源、池的概念;进程等待的价值、进程等待的方法 wait 和 waitpid(常用)、int* status、阻塞和非阻塞、如何理解等待、W IFEXITED、WEXITSTATUS、WTERMSIG;什么是进程替换 && 为什么要进程替换、替换原理、7个exec系列的替换函数、模拟shell解释器;
335 1
【Linux进程控制】进程创建 | 进程终止 | 进程等待 | 进程替换

热门文章

最新文章

相关实验场景

更多