美文网首页
自定义systend服务

自定义systend服务

作者: Vincent_6c5f | 来源:发表于2019-04-11 09:38 被阅读0次

    自定义systend服务

    自定义systend服务,需要3个文件,

    1. dome.service 服务文件
    2. dome.sh 程序文件本身
    3. dome_st.sh start restart stop 判断文件

    dome.service配置文件

    [Unit]
    Description=Set RBD IOPS Systemd Service
    After=network.target remote-fs.target nss-lookup.target
    
    [Service]
    Environment=PYTHONPATH=/usr/share/openattic/
    Type=simple
    Restart=always
    ExecStart=/usr/bin/python2.7 /usr/share/openattic/alerts/setiops.py &> /dev/null &
    ExecReload=/usr/bin/sh /usr/share/openattic/alerts/alertser.sh iopsrestart
    ExecStop=/usr/bin/sh /usr/share/openattic/alerts/alertser.sh iopsstop
    
    [Install]
    WantedBy=multi-user.target
    

    [Unit]区块通常是配置文件的第一个区块,用来定义Unit的元数据,以及配置与其他Unit的关系,它的主要字段如下:

    Description:简单描述
    Documentation:服务的启动文件和配置文件
    Requires:当前Unit依赖的其他Unit,如果它们没有运行,当前Unit会启动失败
    Wants:与当前Unit配合的其他Unit,如果它们没有运行,不影响当前Unit的启动
    BindsTo:与Requires类似,它指定的Unit如果退出,会导致当前Unit停止运行
    Before:如果该字段指定的Unit也要启动,那么必须在当前Unit之后启动
    After:如果该字段指定的Unit也要启动,那么必须在当前Unit之前启动
    Conflicts:这里指定的Unit不能与当前Unit同时运行
    Condition...:当前Unit运行必须满足的条件,否则不会运行
    Assert...:当前Unit运行必须满足的条件,否则会报启动失败
    

    [Service]区块配置,只有Service类型的Unit才有这个区块,它的主要字段如下:

    Type:定义启动时的进程行为,它有以下几种值。
    Type=simple:默认值,执行ExecStart指定的命令,启动主进程
    Type=forking:以fork方式从父进程创建子进程,之后父进程会退出,子进程成为主进程
    Type=oneshot:一次性进程,Systemd会等当前服务退出,再继续往下执行
    Type=dbus:当前服务通过D-Bus启动
    Type=notify:当前服务启动完毕,会通知Systemd,再继续往下执行
    Type=idle:若有其他任务,则其他任务执行完毕,当前服务才会运行
    ExecStart:启动当前服务的命令
    ExecStartPre:启动当前服务之前执行的命令
    ExecStartPost:启动当前服务之后执行的命令
    ExecReload:重启当前服务时执行的命令
    ExecStop:停止当前服务时执行的命令
    ExecStopPost:停止当其服务之后执行的命令
    RestartSec:自动重启当前服务间隔的秒数
    Restart:定义何种情况Systemd会自动重启当前服务,可能的值包括always(总是重启)、on-success、on-failure、on-abnormal、on-abort、on-watchdog
    TimeoutSec:定义Systemd停止当前服务之前等待的秒数
    Environment:指定环境变量
    

    [Install]通常是配置文件的最后一个区块,用来定义运行模式(Target)、Unit别名等设置,以及是否开机启动,它的主要字段如下:

    WantedBy:它的值是一个或多个Target,当前Unit激活时(enable)时,符号链接会放入/etc/systemd/system目录下面以Target名+.wants后缀构成的子目录中
    RequiredBy:它的值是一个或多个Target,当前Unit激活时,符号链接会放入/etc/systemd/system目录下面以Target名+.required后缀构成的子目录中
    Alias:当前Unit可用于启动的别名
    Also:当前Unit激活(enable)时,会被同时激活的其他Unit
    

    参考配置

    dome.service配置文件

    [Unit]
    Description=Slotletter Systemd Service
    After=network.target remote-fs.target nss-lookup.target
    
    [Service]
    Environment=PYTHONPATH=/usr/share/openattic/
    Type=simple
    Restart=always
    ExecStart=/usr/bin/python2.7 /usr/share/openattic/alerts/slotletter.py &> /dev/null &
    ExecReload=/usr/bin/sh /usr/share/openattic/alerts/alertser.sh slotrestart
    ExecStop=/usr/bin/sh /usr/share/openattic/alerts/alertser.sh slotstop
    
    [Install]
    WantedBy=multi-user.target
    
    #!/usr/bin/env bash
    #
    action=$1
    export PYTHONPATH=/usr/share/openattic/
    
    ####: slotletter
    slot_pid=`ps -ef|grep 'slotletter'|grep -v grep|awk -F ' ' '{print $2}'|head -n 1`
    slot_pids=`ps -ef|grep 'slotletter'|grep -v grep|awk -F ' ' '{print $2}'`
    
    if [ $1 == 'slotrestart' ]
    then
      if [ ! $slot_pid ]
      then
          python2.7 /usr/share/openattic/alerts/slotletter.py &> /dev/null &
      else
          for pid in $slot_pids
            do
              kill -9 $pid &> /dev/null &
            done
          python2.7 /usr/share/openattic/alerts/slotletter.py &> /dev/null &
      fi
    fi
    
    if [ $1 == 'slotstop' ]
    then
      for pid in $slot_pids
        do
          kill -9 $pid &> /dev/null &
        done
      kill -9 $slot_pid &> /dev/null &
    fi
    

    主程序自行编写,在此不再举例说明。

    本文部分命令参考文献::https://blog.51cto.com/andyxu/2122109?source=dra

    相关文章

      网友评论

          本文标题:自定义systend服务

          本文链接:https://www.haomeiwen.com/subject/ohuziqtx.html