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

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

一、功能介绍

Linux通过命令查找指定的进程是否存在,并返回该进程的PID号。

在程序中可以使用该方法监控指定的程序是否在运行,如果异常退出,可以重新启动指定程序或者系统。

二、执行的命令

2.1 shell脚本代码

#查找指定进程的PID
find_name=s_app #s_app就是要查找的进程名称
pid_val=`ps -ef | grep $find_name | grep -v grep | awk '{print $2}'`
if [ $pid_val > 0 ]
then
  echo "查找的进程存在,对应的PID=${pid_val}"
else
  echo "查找的进程不存在"
fi

image.png

2.2 C语言代码

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
//查找指定的进程的PID号并返回
int find_pid(const char *app_name)
{
    char cmd_buff[100];
    int cnt;
    sprintf(cmd_buff,"ps -ef | grep %s | grep -v grep | awk '{print $2}'",app_name);
    FILE *fp=popen(cmd_buff,"r");
    if(fp==NULL)
    {
        return -1;
    }
    cnt=fread(cmd_buff,1,sizeof(cmd_buff)-1,fp);
    cmd_buff[cnt]='\0';
    pclose(fp);
    //判断是否读取到数据
    if(cnt==0)
    {
        return 0;
    }
    return atoi(cmd_buff);   
}
int main(int argc,char **argv)
{
    int pid;
    //填入要查找的应用程序名称
    pid=find_pid("s_app");
    if(pid==-1)
    {
        printf("查找错误,查找程序未能启动.\n");
    }
    else if(pid==0)
    {
        printf("查找的进程不存在.\n");
    }
    else
    {
        printf("查找的进程PID=%d\n",pid);
    }
    return 0;
}

image.png

三、检测指定程序是否存在,不存在就重新启动

#查找指定进程的PID
find_name=s_app
while :
do
  pid_val=`ps -ef | grep $find_name | grep -v grep | awk '{print $2}'`
  if [ ${pid_val} > 0 ]
  then
    echo "查找的进程存在"
  else
    echo "查找的进程不存在"
    #重新启动
    /mnt/hgfs/linux-share-dir/linux_c/s_app 8080 &
  fi
  sleep 10
done

为了方便启动该脚本,可以在执行程序里增加一行代码,将启动代码追加到系统启动文件里去:

grep -q "/home/wbyq/find_pid.sh &" /home/wbyq/.profile||echo "/home/wbyq/find_pid.sh &" >> /home/wbyq/.profile


目录
相关文章
|
5天前
|
存储 网络协议 Linux
【Linux】进程IO|系统调用|open|write|文件描述符fd|封装|理解一切皆文件
本文详细介绍了Linux中的进程IO与系统调用,包括 `open`、`write`、`read`和 `close`函数及其用法,解释了文件描述符(fd)的概念,并深入探讨了Linux中的“一切皆文件”思想。这种设计极大地简化了系统编程,使得处理不同类型的IO设备变得更加一致和简单。通过本文的学习,您应该能够更好地理解和应用Linux中的进程IO操作,提高系统编程的效率和能力。
53 34
|
9天前
|
消息中间件 Linux C++
c++ linux通过实现独立进程之间的通信和传递字符串 demo
的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。 在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方
40 16
|
1月前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
122 20
|
2月前
|
监控 Linux 数据处理
Linux grep技巧 结合awk查询
结合 `grep` 和 `awk`,可以实现灵活、高效的文本处理和数据分析。`grep` 用于快速过滤符合条件的行,`awk` 用于进一步处理和提取数据。这种组合使用在日志分析、数据处理和系统监控等场景中尤为常见。掌握这两者的基本用法和组合技巧,可以大大提升在 Linux 环境下的工作效率。
61 7
|
2月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
121 13
|
2月前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
2月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
110 1
|
2月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
3月前
|
缓存 算法 Linux
Linux内核的心脏:深入理解进程调度器
本文探讨了Linux操作系统中至关重要的组成部分——进程调度器。通过分析其工作原理、调度算法以及在不同场景下的表现,揭示它是如何高效管理CPU资源,确保系统响应性和公平性的。本文旨在为读者提供一个清晰的视图,了解在多任务环境下,Linux是如何智能地分配处理器时间给各个进程的。
|
3月前
|
网络协议 Linux 虚拟化
如何在 Linux 系统中查看进程的详细信息?
如何在 Linux 系统中查看进程的详细信息?
356 1