以前曾在Linux上维护应用服务,但是只是简单的迭代版本等工作,没有什么技术含量。最近部署在Linux服务器上的一个平台的总线进程broker(下面总线用broker指代)经常挂掉,由于总线负责服务之间通讯,分发消息给各个应用服务,总线一旦挂掉就导致整个平台瘫痪。总线进程挂掉需要人工重启,在没有找到具体原因前维护起来很不方便,而且往往是用户先发现才反馈过来,所以先写一个守护进程,一旦总线挂掉就重启。网上查了很多资料,总算搞出来了,大体写一下实现步骤,即是备忘也分享给大家,相互交流。

  先说一下大体思路:

  1、创建一个脚本文件middle_start,循环查找broker进程是否存在,如果不存在就启动broker;

  2、另外创建一个启动脚本start,启动middle_start,指定middle_start为后台进程;

  3、再创建一个结束end,先结束守护进程,再结束broker。

  第一步的middle_start代码如下:

#! /bin/bash
sysctl -w net.core.wmem_default=
sysctl -w net.core.wmem_max=
sysctl -w net.core.rmem_default=
sysctl -w net.core.rmem_max=
#program directory path
PRO_PATH=$PWD
#program name
PRO_NAME="/broker"
#program path, not need configure.
PRO_MAIN=$PRO_PATH$PRO_NAME
#GNOME start program, not need configure.
PROGRAM_GNOME="gnome-terminal -e \"$PRO_MAIN\""
#start method GNOME or nohup (eg: GNONE-->STAR_PRO=$PROGRAM_GNOME ; nohup-->STAR_METHOD=$PRO_MAIN)
STAR_METHOD=$PRO_MAIN
export LD_LIBRARY_PATH=../../lib:$LD_LIBRARY_PATH while :
do
PRO_NOW=`ps aux | grep $PRO_MAIN | grep -v grep | wc -l`
if [ $PRO_NOW -lt 1 ]; then
echo "-- start broker --"
$STAR_METHOD 2>/dev/null 1>&2 &
curtime=`date +"%Y-%m-%d %H:%M:%S"`
echo "$curtime $PRO_MAIN start" >> $PRO_PATH/tinfo.log
fi
sleep 5
done
exit 0

主要看红色部分。

  第二步的start脚本如下:

#! /bin/bash
./middle_start.sh &

  第三部的end脚本也很简单:

#!/bin/bash
#progress name
PRO_NAME="middle_start.sh"
BRK_NAME="broker" ps -ef|grep $PRO_NAME |grep -v grep|awk '{print $2}'|xargs kill
echo "kill $PRO_NAME done!"
ps -ef|grep $BRK_NAME |grep -v grep|awk '{print $2}'|xargs kill -
echo "kill $BRK_NAME done"

  完成上面的步骤后,启动start脚本,ps查询broker已经运行,强行kill掉后broker仍然存在,已经是小强般的存在,执行end后broker销毁。

最新文章

  1. [已解决]:调用 LoadLibraryEx 失败,在 ISAPI 筛选器 "c:\Windows\Microsoft.NET\Framework\v4.0.30319\\aspnet_filter.
  2. gradle修改AndroidManifest.xml中的版本号
  3. centos下ssh无密码验证
  4. Factory Method(工厂方法)-对象创建型模式
  5. Android事件传递机制
  6. rsync 参数断点续传
  7. 【设计模式 - 5】之适配器模式(Adapter)
  8. spring mvc DispatcherServlet详解之一--request通过HandlerMaping获取控制器Controller过程
  9. vue做的第二个app
  10. C#多线程和线程池问题
  11. JS 正则表达式深入
  12. hibernate环境搭建及操作
  13. Codeforces 1114 简要题解
  14. ajax读取txt文本时乱码的解决方案
  15. HDU - 1828 Picture
  16. vnc操作指南
  17. bzoj千题计划286:bzoj1226: [SDOI2009]学校食堂Dining
  18. WPF图形图像相关类
  19. CF 557B(Pasha and Tea-贪心)
  20. OpenStack 业务链networking-sfc介绍 (1) - 概述

热门文章

  1. pandas_查看数据特征和统计信息
  2. Kylin Flink Cube 引擎的前世今生
  3. PHP fgetc() 函数
  4. Skill 如何翻转一个list
  5. luogu P1526 [NOI2003]智破连环阵 搜索+最大匹配+剪枝
  6. Linux的VMWare中Centos7查看文件内容命令 (more-less-head-tail)
  7. Dockerfile你值得拥有
  8. 什么是Cookie、Session、Token?
  9. 详解Flask上下文
  10. MySQL进阶篇(03):合理的使用索引结构和查询