一、公司的类似ansible的工具也是用supervise管理的

[admin@mjyall-test-1 /service/ansible-oc-agent]$ ps -ef|grep 19070
root 19070 19068 0 00:44 ? 00:00:00 svscan /service
root 19072 19070 0 00:44 ? 00:00:00 supervise ansible-oc-agent
root 19073 19070 0 00:44 ? 00:00:00 supervise log
[admin@mjyall-test-1 /service/ansible-oc-agent]$ sudo tree .
.
├── log
│   ├── run
│   └── supervise
│   ├── control
│   ├── lock
│   ├── ok
│   └── status
├── run
└── supervise
├── control
├── lock
├── ok
└── status 3 directories, 10 files
[admin@mjyall-test-1 /service/ansible-oc-agent]$ cat run
#!/bin/bash . /etc/profile mkdir -p /opt/ansible-oc-agent/cache
cd /opt/eoc-agent exec 2>&1
exec /opt/ansible-oc-agent/bin/startup.sh

二、常用命令集合。

#官网:https://cr.yp.to/daemontools/svc.html
svc -d /service/eoc-agent && sleep 10  &&  svc -k /service/eoc-agent  && svc -u /service/eoc-agent #重启eoc-agent
svstat /service/eoc-agent #查看jyalloc-agent状态
   svc -d /service/eoc-agent  关闭
   svc -u /service/eoc-agent  打开

三、daemontools自带命令详解

[root@xxx-opstools-2 /opt/ops/cmdb]# rpm -ql daemontools
/usr/bin/envdir
/usr/bin/envuidgid
/usr/bin/fghack
/usr/bin/multilog
/usr/bin/pgrphack
/usr/bin/readproctitle
/usr/bin/setlock
/usr/bin/setuidgid
/usr/bin/softlimit
/usr/bin/supervise
/usr/bin/svc
/usr/bin/svok
/usr/bin/svscan
/usr/bin/svscanboot
/usr/bin/svstat
/usr/bin/tai64n
/usr/bin/tai64nlocal
cat /usr/lib/systemd/system/daemontools.service systemctl status daemontools #查看通过daemontools控制的服务的状态

[Unit]
   Description=daemontools
   After=sysinit.target

[Service]
   ExecStart=/usr/bin/svscanboot
   Restart=always

[Install]
   WantedBy=multi-user.target

(1)envdir   设置环境变量用的, Reference:https://cr.yp.to/daemontools/envdir.html

(2)envuidgid  设置运行脚本的uid and gid, Reference:https://cr.yp.to/daemontools/envuidgid.html

(3)fghack   fghack is an anti-backgrounding tool.   Reference:https://cr.yp.to/daemontools/fghack.html

(4)multilog  multilog reads a sequence of lines from stdin and appends selected lines to any number of logs.

root      2386  2384  0  2017 ?        00:00:25 multilog t s10485760 n5 /opt/eoc-agent/logs

<1>解释下这里"t"时间戳的意义:

Timestamping
The action
t
inserts an @, a precise timestamp, and a space in front of each line, using the same format as tai64n. This is required to be the first action.
Patterns apply to the line after the timestamp is inserted. For example, if multilog t '-*' '+* fatal: *' ./main
reads the line
fatal: out of memory
then it will log a line such as
@400000003b4a39c23294b13c fatal: out of memory
with the first * matching the timestamp.
You can use tai64nlocal to convert these timestamps to human-readable form.

<2>Automatically rotated logs日志文件解释

日志文件大小size must be between 4096 and 16777215. The default maximum file size is 99999.单位为byte

@表示已经写完的老的文件,current表示当前正在写的

.s: This file is completely processed and safely written to disk.
.u: This file was being created at the moment of an outage. It may have been truncated. It has not been processed.

(5)pgrphack    pgrphack runs a program in a separate process group.

(6)readproctitle maintains an automatically rotated log in memory for inspection by ps.

(7)setlock runs another program with a file locked.

(8)setuidgid runs another program under a specified account's uid and gid.

(9)softlimit runs another program with new resource limits.

(10)supervise starts and monitors a service.

也可以用svc()进行启动<https://cr.yp.to/daemontools/svc.html>.

状态查看使用svstat()<https://cr.yp.to/daemontools/svstat.html>.

svok检查是否服务是ok的<https://cr.yp.to/daemontools/svok.html>.

svscan to reliably start a collection of supervise processes(批量启动supervisor服务,上限为1000个子目录,而且它是永久启动的,并且会不断扫描新的目录)<https://cr.yp.to/daemontools/svscan.html>.

(11)启动服务

svscanboot starts svscan in the /service directory

(12) tai64n puts a precise timestamp on each line.

(13)tai64nlocal converts precise TAI64N timestamps to a human-readable format.

If a line begins with @, tai64nlocal looks for a timestamp after the @, in the format printed by tai64n, and writes the line to stdout with the timestamp converted to local time in ISO format: YYYY-MM-DD HH:MM:SS.SSSSSSSSS.

Reference:

https://cr.yp.to/daemontools.html

https://isotope11.com/blog/manage-your-services-with-daemontools

https://blog.csdn.net/u012373815/article/details/70217030

021_supervise进行管理利器的更多相关文章

  1. [转]Linux后台进程管理利器:supervisor

    FROM : http://www.liaoxuefeng.com/article/0013738926914703df5e93589a14c19807f0e285194fe84000 Linux后台 ...

  2. Docker&Kubernetes沙龙干货集锦:容器集群管理利器kubernetes详谈-CSDN.NET

    Docker&Kubernetes沙龙干货集锦:容器集群管理利器kubernetes详谈-CSDN.NET undefined Package - crawler undefined 科学网- ...

  3. KVM镜像管理利器-guestfish使用详解

    原文  http://xiaoli110.blog.51cto.com/1724/1568307   KVM镜像管理利器-guestfish使用详解 本文介绍以下内容: 1. 虚拟机镜像挂载及w2k8 ...

  4. linux下远程管理利器-tmux

    linux下远程管理利器-tmux 1.控制键       控制键就是tmux的主键.当你在tmux环境下按下这个键的时候,tmux就会把你后面输入的指令,解析成它内置的功能.tmux默认的控制键是 ...

  5. scribefire 多博客管理利器 安装详解

    scribefire 多博客管理利器 安装详解 一.ScribeFire介绍 ScribeFire 是 Firefox (火狐浏览器)上著名的博客写作工具,目前已跨平台支持多浏览器(Firefox,C ...

  6. MAC上的包管理利器

    Homebrew- MAC上的包管理利器 2013-07-01 16:25 by 黄博文, 76 阅读, 0 评论, 收藏, 编辑 包管理器是神马东西?让我们看看wikipedia上的介绍. In s ...

  7. 【干货】快速部署微软开源GPU管理利器: OpenPAI

    [干货]快速部署微软开源GPU管理利器: OpenPAI 介绍 不管是机器学习的老手,还是入门的新人,都应该装备上尽可能强大的算力.除此之外,还要压榨出硬件的所有潜力来加快模型训练.OpenPAI作为 ...

  8. SDK管理利器——sdkman

    SDK管理利器--sdkman 项目使用java的开发者一定会为新配环境变量而头大,sdkman很好的解决了系统sdk管理的痛点,仅需简单的几行命令就可以完成sdk的安装,更改默认版本.再也不用担心环 ...

  9. nrm npm源管理利器

    nrm npm源管理利器 nrm是管理npm源的一个利器. 有时候我们用npm install 安装依赖时会非常的慢,是官方自身的npm本来就慢,然后我们会尝试安装淘宝的npm或者cnpm,这些安装切 ...

随机推荐

  1. STM32学习笔记:【002】BIN文件通过ST-LINK烧录STM32芯片

    以下提供2种下载方式 KEIL编译下载 KEIL 5 在开发中还算是比较强大的一种平台.在开发中通过编译再下载会显得很方便. 尽管这个是老生常谈的问题,但还是在这里补全这个设置步骤 1.点击“魔法棒” ...

  2. MySQL备份工具之mysqldump使用

    MySQL备份工具之mysqldump使用说明 一.备份分类 根据能否停用数据库,将备份类型分为: 1. 冷备:数据库服务停止后备份 2. 温备:只能对数据库进行读操作,不能进行写操作 3. 热备:在 ...

  3. ACM-ICPC 2018 南京赛区网络预赛 E AC Challenge(状压dp)

    https://nanti.jisuanke.com/t/30994 题意 给你n个题目,对于每个题目,在做这个题目之前,规定了必须先做哪几个题目,第t个做的题目i得分是t×ai+bi问最终的最大得分 ...

  4. bzoj千题计划322:bzoj2561: 最小生成树(最小割)

    https://www.lydsy.com/JudgeOnline/problem.php?id=2561 考虑Kruscal算法求最小生成树的流程 如果 u和v之间的长为L的边能出现在最小生成树里, ...

  5. python 调用 java代码

    一.JPype简述 1.JPype是什么? JPype是一个能够让 python 代码方便地调用 Java 代码的工具,从而克服了 python 在某些领域(如服务器端编程)中的不足. 2.JPype ...

  6. NPOI导出Excel2007-xlsx

    今天在用npoi导出xls时会报错,经过在网上查找资料,找到一篇博客文章介绍的,原文地址https://www.cnblogs.com/spring_wang/p/3160020.html 1.今天再 ...

  7. luogu 2216 理想的正方形 单调队列(其实没有DP)

    #include<bits/stdc++.h> using namespace std; ; ; int a,b,n; int g[A][A],q[A][N],Q[A][N]; int h ...

  8. 【codeforces 870F】Paths

    Description You are given a positive integer n. Let's build a graph on vertices 1, 2, ..., n in such ...

  9. Andrew NG 机器学习编程作业5 Octave

    问题描述:根据水库中蓄水标线(water level) 使用正则化的线性回归模型预 水流量(water flowing out of dam),然后 debug 学习算法 以及 讨论偏差和方差对 该线 ...

  10. Nginx 关闭日志生成文件

    nginx 关闭日志:其实一种方法就是写入/dev/null 文件 或者设置关闭: nginx 日志有两个类型  access.log  http 记录访问日志. error.log   server ...