linux——守护进程守护刷抖音程序不被意外退出

2024-01-20 20:50

本文主要是介绍linux——守护进程守护刷抖音程序不被意外退出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先搞清楚几个概念:

udev:

设备管理工具,以守护进程的方式工作。位于应用层,主要用于监听内核硬件状态,它能够根据系统中的硬

件设备的状态动态更新设备文件,包括设备文件的创建,删除等

守护进程:

  1. 守护进程和终端无关联,也就是他们没有控制终端,所以当控制终端退出,也不会导致守护进程退出

  1. 守护进程是在后台运行,不会占着终端,终端可以执行其他命令

  1. 一个守护进程的父进程是init进程,因为它真正的父进程在fork出子进程后就先于子进程exit退出

  1. 了,所以它是一个由init继承的孤儿进程

ps -elf:查看系统进程,一般为d结尾的就是守护进程(用户),带[]的表示内核的守护进程

用守护进程的方式不让刷抖音程序意外退出:

直接借助damon()函数完成

#include <unistd.h>
int daemon(int nochdir, int noclose);
/*函数参数:
nochdir:为0时表示将当前目录更改至“/”,目的是为了和用户目录不挂钩,用户目录一般为/orangepi
noclose:为0时表示将标准输入、标准输出、标准错误重定向至“/dev/null”
返回值:
成功则返回0,失败返回-1
*/
#include <unistd.h>
#include <signal.h>
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <time.h>
#include <stdio.h>
//C 库函数 char *asctime(const struct tm *timeptr) 返回一个指向字符串的指针,它代表了结
//构 struct timeptr 的日期和时间。
//C 库函数 struct tm *localtime(const time_t *timer) 使用 timer 的值来填充 tm 结构。
//timer 的值被分解为 tm 结构,并用本地时区表示。
/*
struct tm {
int tm_sec; 秒,范围从 0 到 59
int tm_min; 分,范围从 0 到 59
int tm_hour; 小时,范围从 0 到 23
int tm_mday; 一月中的第几天,范围从 1 到 31
int tm_mon; 月份,范围从 0 到 11
int tm_year; 自 1900 起的年数
int tm_wday; 一周中的第几天,范围从 0 到 6
int tm_yday; 一年中的第几天,范围从 0 到 365
int tm_isdst; 夏令时
};
*/
static bool flag = true;
void handler(int sig)
{
printf("I got a signal %d\nI'm quitting.\n", sig);
flag = false;
}
int main()
{
time_t t;
int fd;
//创建守护进程
if(-1 == daemon(0, 0))
{
printf("daemon error\n");
exit(1);
}
//设置信号处理函数
struct sigaction act;
act.sa_handler = handler;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
if(sigaction(SIGQUIT, &act, NULL))
{
printf("sigaction error.\n");
exit(0);
}
//进程工作内容
while(flag)
{
fd = open("/home/orangepi/daemon.log", O_WRONLY | O_CREAT | O_APPEND,
0644);
if(fd == -1)
{
printf("open error\n");
}
t = time(0);
char *buf = asctime(localtime(&t));//获取时间,并把时间转换成人类可以看懂的形式
write(fd, buf, strlen(buf));
close(fd);
sleep(10);//休眠10秒
}
return 0;}

编译运行上述代码可以看到,运行没有任何结果输出,但是查看系统进程可以发现,有个父进程为1的进程,这个就是编写的守护进程,并且在工作目录底下可以看到日志文件,每隔十秒发送时间相关信息(代码有解析),日志文件内容如下:

实现守护进程开机自启动:

:sudo vi /etc/rc.local(打开这个文件)

:找到守护进程的可执行文件路径(我的是/home/orangepi/tdamon)

把它放进文件里就ok了

:sudo reboot(重启试一下)

成功!

开始实现刷抖音程序的守护进程

第一步:

写个脚本来搜索刷抖音的程序

  1 #include <stdio.h>2 #include <string.h>3 int main()4 {5     FILE *file;67     char *cmd = "ps -elf|grep shuadouy|grep -v grep";8     char buffer[128] = {'\0'};//定义一个128个字节的数组,并且全部初始化为09     file = popen(cmd,"r");//相对于open的好处在于可以读取终端上打印的东西1011     fgets(buffer,128,file);//在file这个文件里面读取128个字节到buffer里面去1213     if(strstr(buffer,"shuadouy") != NULL){//在buffer里面判断是否有"shuadouy"这样的字串14         printf("shuhadouy pro is running!\n");1516     }else{17         printf("shuhadouy pro is error!\n");181920     }21     printf("buffer:%s\n",buffer);22 }

打开和关闭刷抖音程序时:

第二步:把抖音进程和守护进程关联起来

#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <time.h>
#include <stdio.h>
#include <stdbool.h>
#include <signal.h>
static bool flag = true;
int daemon(int nochdir, int noclose);
void handler(int sig)
{printf("I got a signal %d\nI'm quitting.\n", sig);flag = false;
}int judMent()
{FILE *file;char *cmd = "ps -elf|grep shuadouy|grep -v grep";char buffer[128] = {'\0'};//定义一个128个字节的数组,并且全部初始化为0file = popen(cmd,"r");//相对于open的好处在于可以读取终端上打印的东西fgets(buffer,128,file);//在file这个文件里面读取128个字节到buffer里面去if(strstr(buffer,"shuadouy") != NULL){//在buffer里面判断是否有"shuadouy"这样的字串return 0;}else{return -1;}printf("buffer:%s\n",buffer);}
int main()
{time_t t;int fd;//创建守护进程if(-1 == daemon(0, 0)){printf("daemon error\n");exit(1);}//设置信号处理函数struct sigaction act;act.sa_handler = handler;sigemptyset(&act.sa_mask);act.sa_flags = 0;if(sigaction(SIGQUIT, &act, NULL)){printf("sigaction error.\n");exit(0);}//进程工作内容while(flag){if(judMent() == -1){system("/home/orangepi/douyin/shuadouy /dev/ttyS5 &");//&代表后台运行}sleep(2);}return 0;}

结果就是:

守护进程能跑起来,而且杀不掉,杀掉又会重新来一个id

加入上电自启动:

把守护进程和刷抖音的程序都加进来

全部完成

这篇关于linux——守护进程守护刷抖音程序不被意外退出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务