聊聊进程-2-进程的管理

2024-08-29 10:38
文章标签 管理 进程 聊聊

本文主要是介绍聊聊进程-2-进程的管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

进程的管理是运维的基本功之一,对如何玩转shell十分关键

掌握 进程基础概念

进程的创建

  • 前台进程 python xxx.py
  • 后台进程 python xxx.py &
    • 守护进程 nohup python xxx.py &

查看进程pid

pid

$$ $BASHPID 都可以,他们的区别如下脚本

$ echo $$ $BASHPID | cat -
11656 31528
$ echo $$ $BASHPID
11656 11656
$ echo $$ | while read line; do echo $line $$ $BASHPID; done
11656 11656 31497
$ while read line; do echo $line $$ $BASHPID; done <<< $$
11656 11656 11656

查询ppid

$PPID

查询本机进程树

pstree -p

已加pid后的操作

基本信息

ps -p
top -p

调试该进程

strace -p
gdb program

神奇的proc目录

/proc/

  • cmdline: 用’\0’分隔的命令行参数

  • cwd: 指向进程当前工作路径的符号链接,可以用来查询进程绝对路径

  • environ: 环境变量列表

  • exe: 指向进程执行文件的符号链接

  • fd: 存储该进程打开的文件句柄的符号链接
  • status: 各种状态信息(例如进程ID,内存使用,信号等)
  • task: 包含该进程所有线程的以TID命名的子目录

根据进程名字查找PID

下面几个方法:

ps -ef | grep xxx | grep -v grep | awk '{print $2}'
ps -ef | grep -w [g]xxx | awk '{print $2}'
pgrep -x xxxps -C xxx -o pid

根据PID判断进程存在与否

ps <pid>
[[ -d /proc/<pid> ]]
kill -0 <pid>

kill -0 返回为0,说明给的进程发送信号成功
,意味着
1. 进程存在
2. 权限允许

进程状态说明

  • D: 不可中断的睡眠
  • R: 等待运行,进程处于运行或就绪状态
  • S: 休眠状态
  • T: 停止状态
  • Z: 僵尸状态

进程返回码

$? 表示上一个命令的返回码,返回码范围:[0-255]
一般用 0 表示成功,非0的返回码,bash有一些特殊含义
- 1: 一般错误
- 2: Shell内置命令用法错误
- 126: 调用的命令不可执行
- 127: “命名不存在”
- 128+n: 致命错误信号“n”
- 130: Control-C终止
- 255: exit的状态码不合法

并发实现

  • 通过各个语言实现多进程多线程,这个这里不细讲,忽略
并发下载:
parallel -j5 wget xxxurlxargs –n 1 –P 6 wget xxxurl
Grep超大日志加速
cat biglog | parallel --pipe grep pattern
改写for loop
 doit() {} export -f doit; cat list | parallel doit```#### 传参数
```bash
seq 5 | parallel echo prefix_{}<div class="se-preview-section-delimiter"></div>
像cat | sh一样
 parallel -j 50 < jobs_to_run

这篇关于聊聊进程-2-进程的管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117624

相关文章

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

Linux之UDP和TCP报头管理方式

《Linux之UDP和TCP报头管理方式》文章系统讲解了传输层协议UDP与TCP的核心区别:UDP无连接、不可靠,适合实时传输(如视频),通过端口号标识应用;TCP有连接、可靠,通过确认应答、序号、窗... 目录一、关于端口号1.1 端口号的理解1.2 端口号范围的划分1.3 认识知名端口号1.4 一个进程

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

Linux权限管理与ACL访问控制详解

《Linux权限管理与ACL访问控制详解》Linux权限管理涵盖基本rwx权限(通过chmod设置)、特殊权限(SUID/SGID/StickyBit)及ACL精细授权,由umask决定默认权限,需合... 目录一、基本权限概述1. 基本权限与数字对应关系二、权限管理命令(chmod)1. 字符模式语法2.