首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux下通过grep查找指定的进程是否存在

一、功能介绍 Linux通过命令查找指定的进程是否存在,并返回该进程的PID号。 在程序中可以使用该方法监控指定的程序是否在运行,如果异常退出,可以重新启动指定程序或者系统。...二、执行的命令 2.1 shell脚本代码 #查找指定进程的PID find_name=s_app #s_app就是要查找的进程名称 pid_val=`ps -ef | grep $find_name..."查找的进程不存在" fi 2.2 C语言代码 #include #include #include //查找指定的进程的PID号并返回...\n"); } else { printf("查找的进程PID=%d\n",pid); } return 0; } 三、检测指定程序是否存在,不存在就重新启动...$2}'` if [ ${pid_val} > 0 ] then echo "查找的进程存在" else echo "查找的进程不存在" #重新启动 /mnt/hgfs/linux-share-dir

4.4K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    如何查找僵尸进程并Kill之,杀不掉的要查看父进程并杀之

    用ps和grep命令寻找僵尸进程 #ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 命令注解: -A 参数列出所有进程 -o 自定义输出字段 我们设定显示字段为...stat(状态), ppid(进程父id), pid(进程id),cmd(命令)这四个参数 因为状态为 z或者Z的进程为僵尸进程,所以我们使用grep抓取stat状态为zZ进程 运行结果参考如下...Z 12334 12339 /path/cmd 这时,我们可以使用 kill -HUP 12339来杀掉这个僵尸进程 运行后,可以再次运行ps -A -ostat,ppid,pid,cmd | grep...-e '^[Zz]'来确认是否已经将僵尸进程杀死 如果kill 子进程的无效,可以尝试kill 其父进程来解决问题,例如上面例子父进程pid是 12334,那么我们就运行 #kill -HUP 12334...来解决问题 一般可以用top命令发现动态进程表 #top ?

    2.4K20

    如何从EPROCESS辨别一个进程是否已退出

    前面已经通过遍历活动进程双链,来得到一个进程列表. 但是,这个链表中有些进程其实是已经退出的进程. 因此,在得到一个EPROCESS之后,必须对其进行识别,判断其是否已经退出....通过对一死一活两个进程的EPROCESS的对比,发现以下标志可以用作判断进程是否退出的标准....WorkingSetAcquiredUnsafe : 0 '' +0x258 Cookie : 0xf02d7ae4 以上标志大部分都可以可靠地用作识别的标志,通常使用ObjectTable的指针是否为...NULL来判断进程是否已经退出.由些也可以知道,Idle进程比较特殊,也是一个ObjectTable为NULL的死进程,但其ExitTime却为0(即没有退出),看来要遍历进程做判断的话,还是用ObjectTable

    1.1K20

    Linux运维必知:如何从其 PID 中查找进程名称

    如果您知道进程的名称,则可以使用 ps 命令轻松获取其进程 ID (PID): ps -p PID -o comm= ps 命令用于进程相关的操作,在上面的命令中,-p PID提供进程 ID 并-o comm...这是一个实际的例子: [202202281053386.png] 老实说,很难记住奇怪的ps -p PID -o comm=语法,如果是这种情况,您可以查看 ps 命令的手册页或使用其他方式获取详细信息...您可以使用 ps 命令或 top 命令列出所有正在运行的进程,并根据需要记下进程 ID 和进程名称。...[202202281053716.png] 如果您知道 PID,则可以简单地使用 grep 命令过滤输出并获取该 PID 的详细信息: ps aux | grep PID 但如下图所示,输出提供了其他详细信息以及进程名称...额外提示:既然我们在谈论进程名称和 PID,让我快速向您展示相反的方法,即从进程名称中找到 PID。

    5.5K20

    【Linux】解析在【进程PCB】中是如何实现【信号的处理方式(抵达未决阻塞)】

    信号从产生到递达 之间 的状态 信号阻塞 (Block):进程可以选择阻塞 (Block )某个信号。...注意: 被阻塞 的信号产生时将 保持在未决状态 ,直到进程解除对此信号的阻塞,才执行递达的动作....(pending),还有一个函数指针表示处理动作 信号集(sigeset_t): 这个类型可以表示每个信号的“有效”或“无效”状态; 非0即1 在阻塞信号集中“有效”和“无效”的含义是该信号是否被阻塞...而在未决信号集中“有效”和“无效”的含义是该信号是否处于未决状态 信号集表表的作用机制: 信号产生时,pending位图为1;递达后设置为0——只要block位图为1,就无法递答 阻塞信号,设置...block位图为1;阻塞状态解除后设置成0; 2.演示阻塞 >在三张表中的表示 演示: 3.如何改变信号的默认实现动作 【1】实现原理:设置信号的【默认处理函数】变成【自定义函数】 每个进程

    13210

    Windows 和 Linux 如何根据端口号查找进程并杀掉它?手把手教你!

    Windows 和 Linux 如何根据端口号查找进程并杀掉它?手把手教你!...前言 作者:神的孩子都在歌唱 在日常的网络运维和开发中,我们常常需要根据 端口号 查找占用该端口的进程,并在必要时终止该进程。不同操作系统下,查找和杀掉进程的方法有所不同。...今天,我们将为你详细讲解在 Windows 和 Linux 系统中,如何根据端口号查找并终止相关进程,帮助你高效解决网络端口占用问题。 一....在 Linux 中根据端口号查找并杀掉进程 Linux 系统下,查找端口占用进程并杀掉进程的方法也相对简单。你可以通过命令行工具来完成这一操作。 2.1 查找端口号对应的进程 1....• 在 Linux 中,如果进程属于其他用户,你可能需要使用 sudo 权限来执行 kill 命令: sudo kill -9 7303 作者:神的孩子都在歌唱 本人博客:https://blog.csdn.net

    10210

    如何在 Linux 中按内存和 CPU 使用率查找运行次数最多的进程

    在这篇文章中,我们将看到使用这些命令按内存和 CPU 使用率显示正在运行的进程的ps命令。 在 Linux 中,ps 代表进程状态。...按内存和 CPU 使用情况查看正在运行的进程 到目前为止,我们已经了解了ps命令是什么、它是如何工作的,以及如何通过 Linux 上的 ps 命令查看整体状态。...我们现在将检查机器上正在运行的进程的 CPU 和内存使用情况。请执行下面给出的以下 ps 命令以查看 Linux 机器上正在运行的进程的内存或 RAM 使用情况。...如何查看更多命令选项 到目前为止,我们已经通过了一些最常用的 ps 命令来查看 Linux 系统上的内存和 CPU 使用情况下正在运行的进程。...每个 Linux 发行版都提供了一个 GUI 工具来监视系统资源。请从您的软件包列表中打开该应用程序并检查基于图形用户界面的系统使用情况。

    3.9K20

    应用稳定性优化系列(一),ANR问题全面解析

    软件绿色联盟联合华为终端开放实验室,通过系列文章对三类故障的产生原因、故障现象、触发机制及如何定位等,展开深度解读。...本期将详解ANR类故障,并通过一个Binder阻塞问题案例,向广大读者演示如何有效定位ANR类故障。...)如果是binder阻塞,查看binder调用链信息,查找对端进程及其对端进程调用stack,找到阻塞函数,如果system_app_anr@XXXX被截断,可以查看traces.txt文件; 4)如果是...3.2 Binder阻塞分析 查找对应的binder transaction信息,分析binder被阻塞的原因。...在Android中一个进程最多会使用16个binder线程,systemserver的全部Binder线程都被阻塞,故不能再分配Binder线程处理其他的Binder消息,导致其他进程给systemserver

    2.8K20

    IO模型梳理-从操作系统到应用层

    同步阻塞IO linux中默认所有socket都是blocking。阻塞就是进程被“休息”,cpu处理其他进程去了。...如果这个轮询工作不是进程自己执行就好了,所以就有了IO多路复用。 Linux下的select,poll,epoll就是干这个的。...它没有最大连接数限制,原因是基于链表存储的,大量的fd数组被整体拷贝到用户态和内核态之间,不管复制是否有意义。...异步非阻塞IO 异步IO不是顺序执行的,用户进程进行系统调用后,无论内核数据是否准备好,都会直接返回给用户进程,然后用户态进程可以去做别的事情,等到socket数据准备好了,内核直接复制数据给进程,然后从内核向进程发送通知...nignx如何做到几十万并发连接,答案是epoll机制,如果100w用户与一个进程保持tcp连接,虽然连接数巨大,但是某个时刻只有一小部分连接是活跃的,所以进程只要处理好这100w连接中的小部分足矣。

    1.2K20

    【Linux】进程信号——信号保存和信号捕捉

    被阻塞的信号将保持未决状态,直到进程解除对此信号的阻塞,才能执行递达的动作。 注意:阻塞信号和忽略信号不同,阻塞信号表示信号没有递达,但是忽略信号表示信号已经抵达了,但是我们的处理方式是忽略处理。...我们从左到右说起: 第一张表是位图,比特位的位置是信号编号,比特位的含义是是否阻塞信号,1表示阻塞当前编号的信号,0表示为阻塞当前信号。...因为我们之前做了阻塞,当收到2号信号的时候,将其阻塞,所以pending表中会一直受到信号。所以如何解决这种情况呢? 我们可以定义一个计数器,当计数器走到10的时候将2号信号进入递达状态。...进程从内核态切换到用户态的时候,操作系统检测当前进程的pending表&&block表,决定是否处理handler表处理信号 假如我们写了一个代码,当我们进行某些系统调用的时候,会出现中断,中断之后会进入内核态...我们学习了信号的基本概念、信号的保存方式(如信号掩码和未决信号集),以及如何通过信号处理函数来捕捉和处理信号。 在实际应用中,合理地使用信号机制可以大大提高程序的健壮性和响应能力。

    9710

    Go调度系列--调度器实现原理(二)

    在上一篇我们已经知道了GMP各自代表的含义,三者之间的关系,今天从调度的角度去看Go是如何将三者之间进行协作的。 进程、线程、协程 讲Go的调度之前,我们对进程、线程、协程这些概念做个简单了解。...还找不到,要去网络轮询器中查找是否有G等待运行;仍找不到,则尝试从其他P中窃取G来执行。...G,大体逻辑如下: 每执行61次调度循环,从全局队列获取G 若有则直接返回从P 上的 runnext 看一下是否有 G 若有则直接返回 从P 上的 本地队列 看一下是否有 G 若有则直接返回 上面都没查找到时...,则去全局队列、网络轮询器查找或者从其他 P 中窃取,一直阻塞直到获取到一个可用的 G 为止 而从全局队列队列获取G也有规则,实现代码如下: func globrunqget(_p_ *p, max int32...当线程M运行的G进行系统调用阻塞时,线程M释放绑定的P,把P转移给其他空闲的线程进行绑定。 ​

    51920

    干货!!字节大佬带你深入分析Node.js的底层原理

    另外我们看到,Poll IO 阶段会可能会阻塞,是否阻塞和阻塞多久取决于事件循环系统当前的状态。...然后主进程就在新的事件循环中执行,旧的事件循环就被阻塞了。 子进程结束的时候,新的事件循环也就结束了,从而回到旧的事件循环。 5.2 进程间通信 接下来我们看一下父子进程间怎么通信呢?...这就是 Node.js 处理一个连接的过程,处理完一个连接后,Node.js 会判断是否设置了 single_accept 标记,如果有则睡眠一段时间,给其他进程处理剩下的连接,一定程度上避免负责不均衡...DNS 因为通过域名查找 IP 或通过 IP 查找域名的 API 是阻塞式的,所以这两个功能是借助了 Libuv 的线程池实现的。...这就是整个查找过程。 其他的 DNS 操作是通过 cares 实现的,cares 是一个异步 DNS 库,我们知道 DNS 是一个应用层协议,cares 就是实现了这个协议。

    2.7K30

    Node.js的底层原理

    另外我们看到,poll io阶段会可能会阻塞,是否阻塞和阻塞多久取决于事件循环系统当前的状态。...同步创建子进程会导致主进程阻塞,具体的实现是 1 主进程中会新建一个新的事件循环结构体,然后基于这个新的事件循环创建一个子进程。 2 然后主进程就在新的事件循环中执行,旧的事件循环就被阻塞了。...文件 文件操作 Node.js中文件操作分为同步和异步模式,同步模式就是在主进程中直接调用文件系统的api,这种方式可能会引起进程的阻塞,异步方式是借助了Libuv线程池,把阻塞操作放到子线程中去处理,...DNS 因为通过域名查找ip或通过ip查找域名的api是阻塞式的,所以这两个功能是借助了Libuv的线程池实现的。...发起一个查找操作的时候,Node.js会往线程池提及一个任务,然后就继续处理其他事情,同时,线程池的子线程会调用库函数做dns查询,查询结束后,子线程会把结果交给主线程。这就是整个查找过程。 ?

    2.1K20

    如何用 Android vitals 解决应用程序的质量问题

    Android vitals 如何显示过度唤醒? 了解你的应用是否在驱动过多的唤醒是 Android vitals 的重要任务。...唤醒警报是否有其他替代方法?...从主线程向另一个进程运行同步绑定调用。与磁盘或网络操作类似,在跨进程边界进行阻塞调用时,程序执行会传递到你无法控制的某个位置。如果其他进程很忙怎么办?如果它需要访问磁盘或网络来响应你的请求怎么办?...我如何检测 ANR 的原因? 查找 ANR 的原因可能会非常棘手,就拿 URL 类来说吧。 你觉得确定两个 URL 是否相同的 URL#equals 方法是否会被阻塞?...通过查看 Android vitals,你可以快速轻松地发现是否存在需要解决的问题。在代码中查找和解决这些问题并不总是那么直截了当,但有些工具和技术可以帮你更高效地完成这些工作。

    2.3K10

    redis全面总结

    redis父进程判断是否有执行save,bgsave,bgrewriteaof的子进程,如果在执行则bgsave命令直接返回, 父进程执行fork操作创建子进程,这个过程父进程阻塞,redis不能执行客户端的任何命令...父进程fork后,bgsave命令返回"backgroud saving started"信息并不再阻塞父进程,并可以相应其他命令 子进程创建RDB文件,根据父进程内存快照生成临时文件,完成对原来文件的替换...redis父进程判断是否存在bgsave/bgrewriteaof的子进程,如果存在就直接返回, 父进程fork出子进程,这个过程父进程阻塞 父进程fork后,bgrewriteaof命令就返回"Background...的时候会阻塞主进程,子进程向硬盘写数据会带来Io压力,AOF持久化,向硬盘写数据的频率越大,IO压力更大,甚至导致AOF阻塞问题, 而在实际场景,根据数据量,应用数据安全的要求,预算限制等不同情况,会有各种各样的持久化策略...上图就是一张哨兵的架构图,我接着说他是如何工作的 每个sentinel节点都需要定期执行向所有主从服务器以及其他sentinel实例发送ping命令 但是当主节点最后一次回复ping命令超过了设置的时间

    38810

    记一次library cache pin等待的处理

    起因 上周我们虚拟化宕机导致上面的2套数据库停机,而这2套数据库和其他数据库有着千丝万缕的联系,这就导致很多进程处于hang的状态,即一直ACTIVE且无法自行结束。...S)或EXCLUSIVE(X)三种方式 一个X 请求 (3) 会被其他任何持有 S 模式(2) 的会话阻塞 一个 S 请求 (2) 会被其他任何持有X模式 (3) 的会话阻塞, 也会被其他X请求 (3)...的会话阻塞 知道了这些我们就来查询下有哪些会话在相互阻塞 SELECT s.sid, kglpnmod "Mode", kglpnreq "Req", SPID "OS Process" FROM vsession_wait...从上面的结果我们可以看出 会话331 和277持有 X(3) 锁,它们阻塞了下面其他的S(2) 请求 3.问题处理 3.1 查找SQL语句 找到了源头我们先看下这2个会话对应的SQL语句 select...发现已经没有锁了 最后查询等待事件,发现也没有了library cache pin等待 ?

    1.1K20

    Linux进程控制

    进程控制 fork函数 进程终止 退出码 常见的退出方式 进程等待 什么是进程等待,为什么要进程等待 阻塞与非阻塞 进程替换 替换原理 替换函数 执行系统命令 执行自己写的程序 模拟实现简易的shell...一共有32个比特位,其中重要的只有16个比特位: 终止信号是一个进程出异常了会受到终止信号,暂时用来判断进程是否正常退出。 退出状态是看结果是否正确。...阻塞与非阻塞 阻塞 父进程一直在等子进程结束回收资源。 非阻塞 父进程一段时间过来看一下子进程是否结束,如果没结束可以做其他事情,这个叫轮询方式。...如果在询问之后不子进程没有准备完毕,父进程则可以做一些其他的事情。 至于非阻塞和阻塞谁更好,这个要看实际场景。...int execlp(const char *file, const char *arg, …); 结尾是p的第一个参数不用去指定路径了,他会在环境变量PATH,进行可执行程序的查找 int

    2.9K00
    领券