生产环境之“进程”两字

简介:

一、进程概念   

  运行中的程序的一个副本,是被载入内存的一个指令集合 进程ID(Process ID,PID)号码被用来标记各个进程UID、GID、和SELinux语境决定对文件系统的存取和访问权限,通常从执行进程的用户来继承 存在生命周期。 


二、进程状态

1)运行状态:running    2)就绪状态:ready  3)睡眠可中断 

4)睡眠不可中断   5)停止状态 stopped   6)僵死状态  zombie    


三、进程管理命令

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


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


pstree命令:  

  pstree - display a tree of processes 

ps命令: 

 ps - report a snapshot of the current processes 

ps [OPTION]... 

   -e:显示所有进程和-a等同  

   -a:显示所有进程和-e等同 

   -f:选项显示其进程的父进程 

   -u:选项显示所有者信息

   -x:包括不链接终端的进程  

   -o:指定属性进行显示:pid,comm,%cpu,%mem,state,tty,euser(effective user),ruser(real user) 

VSZ:Virtual Memory Size,虚拟内存集    RSS:常驻内存集(物理内存集)



    stat状态: 

        R:running 

        S:interruptable sleeping 

        D:uninterruptable sleeping 

        T:stopped 

        Z:zombie  

常用组合:-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


ni:nice值 pri:priority,优先级 psr:processor,cpu编号 rtprio:实时优先级 




pgrep命令:     

    pgrep [options] pattern  

选项:

    -u:uid,进程的生效者 

    -U:real user,真正发起运行命令者

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

    -l: 显示进程名 -a: 显示完整格式的进程名 -P pid: 显示指定进程的子进程 


按确切的程序名称:/sbin/pidof pidof bash   


三、进程管理工具


top:

wKiom1fO2QviW4wrAABChRi3t-E626.png


htop:

wKioL1fQCMjgoP2XAACVOe9-5t0167.png

栏目信息:us:user space 用户空间    sy:内核空间    ni:nice值    wa:等待I0时间    

id:空闲    hi:硬中断    si:软中断    st: stolen 虚拟机偷走的时间  


进程相关参数说明: 

PID:任务的进程号    PPID:进程的父进程的进程号    RUSER:进程的所有者    EUSER:进程的生效用户

TTY:终端   PR:优先级   %CPU:CPU的占有率   %MEM:内存的占有率 S:进程状态    TIME+:CPU工作时间


top:有许多进程内置命令  

1)排序

P:以占据的cpu的百分比,%cpu  M:占据内存的百分比,%MEM  T:累积占据cpu时长time 


2)首部信息

uptime信息:l命令     tasks及cpu信息:t命令      memory信息:m命令


3)退出命令:q 修改刷新时间:s  终止指定进程:k  保存文件:W




kill命令:向进程发送进程控制信号,以实现对进程管理。


1)SIGHUB:无需关闭进程,而让其重读配置文件 

2)SIGINT: 中止正在运行中的进程  

9)SIGKILL: 杀死正在运行的进程    

15)SIGTEM: 中止正在运行的进程,让其运行完,再次杀死   

18)SIGCONT: 继续运行 

19)SIGSTOP: 后台休眠 

指定信号的方法: (1) 信号的数字标识;1, 2, 9 (2) 信号完整名称;SIGHUP (3) 信号的简写名称;HUP


杀死进程的方法: 

按PID:kill [-SIGNAL] pid...   

按名称:killall [-SIGNAL] COMM  

按模式:pkill [options] pattern    

    -SIGNAL

    -u uid:effective user 生效者  

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

    -l:显示进程名 

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

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



作业管理:


linux的作业控制:

1)前台作业:通过终端启动,且启动后一直占据终端


2)后台作业:可通过终端启动,但启动后即转入后台运行 


3)让作业运行在后台:ctrl+z  command &  


4)后台作业虽然被送往后台运行,但其依然与终端相关;退出终端,将关闭 后台作业。如果希望送往后台后,剥离与终端的关系 #screen;command 或者#nohup command & 


5)查看所有作业:jobs   


6) 作业控制: 

fg:把指定的后台作业调回前台 如:fg 1 

bg:让送往后天的作业在后台继续运行 如:bg 1 

kill:终止指定的进程    


演示:


wKiom1fQDQnhdHpKAABSYp_1_Ck569.png



本文转自chengong1013 51CTO博客,原文链接:http://blog.51cto.com/purify/1847456,如需转载请自行联系原作者

相关文章
|
消息中间件 NoSQL Java
【操作系统】生产环境消失的进程如何排查
【操作系统】生产环境消失的进程如何排查
【操作系统】生产环境消失的进程如何排查
|
6月前
|
监控 Linux 应用服务中间件
探索Linux中的`ps`命令:进程监控与分析的利器
探索Linux中的`ps`命令:进程监控与分析的利器
129 13
|
5月前
|
运维 关系型数据库 MySQL
掌握taskset:优化你的Linux进程,提升系统性能
在多核处理器成为现代计算标准的今天,运维人员和性能调优人员面临着如何有效利用这些处理能力的挑战。优化进程运行的位置不仅可以提高性能,还能更好地管理和分配系统资源。 其中,taskset命令是一个强大的工具,它允许管理员将进程绑定到特定的CPU核心,减少上下文切换的开销,从而提升整体效率。
掌握taskset:优化你的Linux进程,提升系统性能
|
5月前
|
弹性计算 Linux 区块链
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
179 4
Linux系统CPU异常占用(minerd 、tplink等挖矿进程)
|
4月前
|
算法 Linux 调度
探索进程调度:Linux内核中的完全公平调度器
【8月更文挑战第2天】在操作系统的心脏——内核中,进程调度算法扮演着至关重要的角色。本文将深入探讨Linux内核中的完全公平调度器(Completely Fair Scheduler, CFS),一个旨在提供公平时间分配给所有进程的调度器。我们将通过代码示例,理解CFS如何管理运行队列、选择下一个运行进程以及如何对实时负载进行响应。文章将揭示CFS的设计哲学,并展示其如何在现代多任务计算环境中实现高效的资源分配。
|
5月前
|
存储 缓存 安全
【Linux】冯诺依曼体系结构与操作系统及其进程
【Linux】冯诺依曼体系结构与操作系统及其进程
171 1
|
5月前
|
小程序 Linux
【编程小实验】利用Linux fork()与文件I/O:父进程与子进程协同实现高效cp命令(前半文件与后半文件并行复制)
这个小程序是在文件IO的基础上去结合父子进程的一个使用,利用父子进程相互独立的特点实现对数据不同的操作
107 2
|
5月前
|
SQL 自然语言处理 网络协议
【Linux开发实战指南】基于TCP、进程数据结构与SQL数据库:构建在线云词典系统(含注册、登录、查询、历史记录管理功能及源码分享)
TCP(Transmission Control Protocol)连接是互联网上最常用的一种面向连接、可靠的、基于字节流的传输层通信协议。建立TCP连接需要经过著名的“三次握手”过程: 1. SYN(同步序列编号):客户端发送一个SYN包给服务器,并进入SYN_SEND状态,等待服务器确认。 2. SYN-ACK:服务器收到SYN包后,回应一个SYN-ACK(SYN+ACKnowledgment)包,告诉客户端其接收到了请求,并同意建立连接,此时服务器进入SYN_RECV状态。 3. ACK(确认字符):客户端收到服务器的SYN-ACK包后,发送一个ACK包给服务器,确认收到了服务器的确
193 1
|
6月前
|
Web App开发 运维 监控
深入探索Linux命令pwdx:揭秘进程工作目录的秘密
`pwdx`命令在Linux中用于显示指定进程的工作目录,基于`/proc`文件系统获取实时信息。简单易用,如`pwdx 1234`显示PID为1234的进程目录。结合`ps`和`pgrep`等命令可扩展使用,如查看所有进程或特定进程(如Firefox)的目录。使用时注意权限、进程ID的有效性和与其他命令的配合。查阅`man pwdx`获取更多帮助。
|
6月前
|
存储 Shell Linux
Linux进程概念(下)
本文详细的介绍了环境变量和进程空间的概念及其相关的知识。
39 0
Linux进程概念(下)

相关实验场景

更多