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

使用supervisor进行守护进程,防止服务挂掉

最近项目中使用的数据接口服务如TSDB,kafka,订阅服务等在挂掉几次后,为了防止影响主系统的使用,我们要进行守护进程,在进程挂掉后自动拉起。...1.安装教程  https://www.cnblogs.com/toutou/p/supervisor.html 2.上面那个有问题的时候,在linux有python和pip的时候根据下面的教程安装...root numprocs=1 redirect_stderr=true stdout_logfile=/etc/supervisor/logs/kafkaRedis.log 我有三个需要守护的进程...stale socket /tmp/supervisor.sock 就执行以下命令 unlink /tmp/supervisor.sock 解决启动,启动完可以通过supervisorctl查看检测的进程...通过ps -ef|grep 端口号命令  查看进程是否在线 再通过kill -9 端口号命令杀死进程再看程序会不会自动拉起 根据上图看到,在我kill掉进程之后supervisor自动拉起了守护的进程

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

Linux TCP通信出现CLOSE_WAIT后导致服务端进程挂掉

在前文中讲述了Linux服务端TCP通信出现CLOSE_WAIT状态的原因,这篇文章主要通过一个实例演示它个一个“恶劣”影响:直接使服务端进程Down掉。...这时Linux服务端进程会执行第90行处的close()函数,也即执行正常四次挥手关闭TCP连接。...接着Linux服务端进程继续从内核中已完成连接队列中取出已完成连接,这样之前小节3中Windows telnet建立的客户端连接被读取。...如下图所示,服务端进程打印了第80行出的数据(Accept client[192.168.1.110:64012].),但是服务端进程挂掉了。...这时在Linux中再次使用netstat_nap.sh脚本和lsof命令: 6 原因分析 由于Windows客户端的TCP链路在小节4中由于RST的缘故而关闭了,没有读端。

9110

Linux 僵尸进程产生原因及解决方法

Linux 允许进程查询内核以获得其父进程的 PID,或者其任何子进程的执行状态。例如,进程可以创建一个子进程来执行特定的任务,然后调用诸如 wait() 这样的一些库函数检查子进程是否终止。...如果子进程已经终止,那么,它的终止代号将告诉父进程这个任务是否已成功地完成。 为了遵循这些设计原则,不允许 Linux 内核在进程一终止后就丢弃包含在进程描述符字段中的数据。...只有父进程发出了与被终止的进程相关的 wait() 类系统调用之后,才允许这样做。这就是引入僵死状态的原因:尽管从技术上来说进程已死,但必须保存它的描述符,直到父进程得到通知。...任何进程在刚终止时都是僵尸进程,正常情况下,僵尸进程都立刻被父进程清理了。...因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看看有没有哪个 进程是刚刚结束的这个进程的子进程,如果是的话,就由Init进程来接管他,成为他的父进程,从而保证每个进程都会有一个父进程

11K21

Linux中父进程为何要苦苦地知道子进程的死亡原因

白发人送黑发人 一个普遍的常识是,在Linux里面总是“白发人送黑发人”,子进程死亡,父进程透过wait()等待子进程死亡,并清理子进程僵尸,当然父进程也可以因此而获得子进程的死亡原因。...上述代码中,子进程在第18行通过pause()等待信号,父进程在代码的第22行通过waitpid()等待子进程的结束。其中的参数status是一个输出参数,可以获得子进程死亡的原因。...父进程为什么一定要苦苦地知道子进程的死亡原因? 前一个问题很好回答,如果我们用init进程启动了一个httpd的服务供客户访问我们的网站,然后httpd进程半夜挂了。...所以,这个过程应该由Linux的某种机制自动完成,比如如果init知道了httpd死亡的话,它可以内在地自动重新启动一个httpd进程。...,完全可以根据子进程的死亡原因,决定进一步的对策。

2K20

浅析Linux下利用coredump技术追查进程崩溃原因

最近项目中出现了一个问题,服务器端程序会突然崩溃退出,我们采取了coredump技术以找到崩溃原因,即确定进程退出时正在执行的函数是哪个,其状态如何。...如果系统开启了coredump,准确的说如果当前的shell环境开启了coredump,当前shell环境下的程序崩溃退出时,会把当时进程的栈的内存状态写入core文件。...(关于coredump的开启和对shell的理解,请参考本人另一篇博客《使用dotnet-dump 查找 .net core 3.0 占用CPU 100%的原因解析》,关于gdb请参考《gdb调试命令的使用及总结...可见,进程退出时,执行的最后一个函数是square函数。...———————————————— 总结 以上所述是小编给大家介绍的Linux下利用coredump技术追查进程崩溃原因,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

2.1K31

记一次java进程频繁挂掉问题排查修复

前言 最近业务部门有个java服务进程会突然无缘无故的挂掉,然后这个服务会产生一堆类似hs_err_pid19287.log这样的日志。...我们可以使用 abrt-cli list 确认core状态对应的进程及触发时间。...但这个是不是导致java进程频繁挂掉原因,于是我们做了这么一步,将无法创建ccpp文件的时间点和生成的hs_err_pidxxx时间点做个对比 时间点基本上是吻合的,而且/var/log/messages...综上基本上可以确定是因为无法创建ccpp文件导致,导致该业务的java进程频繁挂掉原因之一 如何修复 方法一:将ProcessUnpackaged改为yes 这个参数的意思是表示ABRT将非rpm安装程序...systemctl disable abrt-ccpp.service systemctl status abrt-ccpp.service 总结 执行了如上操作,业务部门观察了一段时间,没有再发现java进行频繁挂掉问题

11210

Linux 下使用 Monit 实现服务挂掉自动拉起

背景 由于应用稳定性或者服务器资源限制等问题,应用就会出现自动挂掉的情况,此时就需要自动拉起应用。 生产环境,为了防止因为意外宕机造成服务长时间中断,一般都会设置服务进程监控拉起机制。...可以用来监控和管理进程、程序、文件、目录和设备等。...优点 安装配置简单,超轻量 可以监控前后台进程(Supervisor 无法监控后台启动进程) 除了监控进程还可以监控文件,还可以监控系统资源(CPU,内存,磁盘)使用率 可以设置进程依赖,控制启动顺序...All Rights Reserved. 12 13# 启动服务 14$ systemctl start monit 15 16# 启动 monit 守护进程 17$ monit 命令 官方手册:https...进程监控信息: ?

2K20

linux通过进程名杀死进程_linux关闭进程命令

笔记:根据一个进程的名字或启动此进程的命令(连续的一部分即可)杀死进程 一、使用单条命令 ps -ef | grep 进程名/启动进程的命令 | grep -v grep | awk ‘{print $2...}’ | xargs kill -9 执行结果: [1]-  已杀死               sleep 200 [2]+  已杀死               sleep 200 二、编写脚本 linux.../bin/bash # 脚本名:kill_process.sh # 脚本功能:强制杀死进程 方式kill -9     # 1通过ps查询进程的id     # 2使用kill -9 强制终止进程...函数功能:根据进程名杀死程序     参数:进程名     返回值:无 !...————————————————————— # 根据进程名查询包含进程名的进程 并排除grep查询进程和此脚本进程 ps -ef | grep “$pName” | grep -v grep | grep

15.8K20

Linux进程学习【进程状态】

阻塞 就是 进程 因等待某种条件就绪,而导致的一种不推进状态 通俗来说,阻塞 就是 进程 卡住了,原因就是缺少资源 比如在我们日常生活中,常常发生堵车,原因就是道路资源不够用了,车辆这个 进程 就需要原地等待...进程 为 阻塞 状态 总结 进程阻塞就是不被调度 原因 进程的 task_struct 结构体需要在某种被 OS 管理的资源下排队 挂起 理解 进程阻塞 后,理解 进程挂起 就比较轻松了 挂起(...,即把手机揣进兜里,然后 专心执行走路这个 进程 进程状态 进程 有各种运行状态,方便OS进行管理,在 Windows 中,进程 状态是这样的 而在我们 Linux 中,新建、就绪、运行都可以看作...运行 R 这一个状态,所以比较清晰 而我们今天要学习的正是 Linux 中的 进程 状态 进程是何种状态,取决于此进程的PCB在哪里排队 ️运行 R 首先来看看第一种状态 R 以我们以往的认知来说...父进程,此时 子进程 会被OS领养 子进程 的 父进程 变为 1号进程进程 就变成了一个 孤儿进程 发出指令终止 父进程 假设 子进程 不被 1号进程 领养 子进程 退出时就会无人回收

19430

Linux进程学习【进程地址】

原因: 当子进程尝试修改共享值时,发生 写时拷贝 机制 语言层面的程序空间地址不是真实物理地址 一般将此地址称为 虚拟地址 或 线性地址 结论: 语言层面的地址都是虚拟地址,用户无法看到真实的物理地址,...因为每个进程都有属于自己的空间,OS 在管理进程时,能够以统一的视角进行管理,效率很高 光有 虚拟地址空间 是不够的,还需要一套完整的 ‘‘翻译’’ 机制进行程序寻址,如 Linux 中的 页表 +...️写时拷贝 Linux 中存在一个很有意思的机制:写时拷贝 这是一种 赌bo 行为,OS 此时就赌你不会对数据进行修改,这样就可以 使多个 进程 在访问同一个数据时,指向同一块空间,当发生改写行为时... using namespace std; int main() { string s; cout << sizeof(s) << endl; return 0; } 原因...(权限设置) 将 进程管理 和 内存管理 进行 解耦,方便 OS 进行更高效的管理 可以让进程以统一的视角看待自己的代码和数据 ---- 总结 以上就是本篇关于 Linux进程学习【进程地址】的全部内容了

14720

Linux进程调度_linux进程的查看和调度

对于处理器消耗型的进程,调度策略往往是降低他们的执行频率,延长运行时间。 Linux 系统为了提升响应的速度,倾向于优先调度 I/O 消耗型。...一、普通进程Linux 中普通进程依赖称之为 nice 值 的东东来进行进程的优先级描述。nice 值的范围是 [-20, 19]。...—— 小结 实时进程优先级:value 越高,优先级越大 普通进程优先级:nice值越高,普通进程的优先级越小 任何实时进程的优先级 > 普通进程 Linux 调度算法 ---- Linux 中有一个总的调度结构...Linux 调度时机 ---- 一、进程切换 从进程的角度看,CPU是共享资源,由所有的进程按特定的策略轮番使用。...发生抢占的原因主要有:进程的时间片用完了,或者优先级更高的进程来争夺CPU了。

20.5K10

Linux进程状态

二.通过系统调用获取标识符 linux中可以通过 系统调用接口:getpid 获取该进程的PID,getppid可以获取父进程的PID  例: #include #include...} 三.fork函数的认识与理解 fork认识  linux输入 man fork 可以看到以上信息:       1.fork包含在头文件 中;       2.返回值是 pid_t...一般情况下,子进程和父进程也是共享数据的,但是一直共享数据也不现实,因为当我们要修改数据时,会把两个进程的数据都改了,这并不是我们想要的,但是重新开一块空间拷贝父进程的数据又有点浪费,所以linux就使用了一种叫写时拷贝的技术...linux进程的状态 linux中的进程状态分为这几种 static const char * const task_state_array[] = { "R (running)", /* 0...孤儿进程 如果父进程先退出,子进程就称之为“孤儿进程”,此时孤儿进程在后台运行; 孤儿进程会被1号init进程领养,最后由init进程回收; 孤儿进程退出不会成为僵尸进程,因此也不会资源泄露。

17210

Linux进程编程

执行过程如下: Linux内核在进程表中为子进程分配一个表项,然后分配PID。...子进程表项的内容来自父进程,fork会将父进程的表项复制为副本,并分配给子进程Linux内核使父进程的文件表和索引表的节点自增1,创建用户及上下文; 将父进程上下文复制到子进程上下文空间中; fork...fork出错可能有两种原因: 当前的进程数已经达到了系统规定的上限,这时errno的值被设置为EAGAIN; 系统内存不足,这时errno的值被设置为ENOMEM。...这里的可执行文件既可以是二进制文件,也可以是任何Linux下可执行的脚本文件。...功能: 以新进程代替原有进程,但PID保持不变。 返回值: 执行成功不返回,出错则返回-1,失败原因记录在errno中。

7.8K20

linux进程调度

调度策略 进程可以分为实时进程和普通进程,对于这两种不同类型的进程肯定有不同的调度策略,task_struct中的policy就用来表示调度策略。...task_struct中配有优先级,需要注意的是优先级数越小优先级越高,实时进程的优先级处于099之间,普通进程的优先级处于100139。...普通调度策略有 SCHED_NORMAL, SCHED_BATCH,SCHED_IDLE SCHED_NORMAL:普通的进程 SCHED_BATCH:后台进程 SCHED_IDLE:空闲时运行的进程...,可以打断所有其他进程,并且该进程不会被抢占 rt_sched_class:RR算法或者FIFO算法的调度策略,具体由该进程的task_struct->policy决定。...CFS为每个进程定义一个虚拟运行时间vruntime,每次总是选择vruntime最小的那个进程进程得到处理机后变随着其运行时间的增加 增加其vruntime。

8K20
领券