久久精品精选,精品九九视频,www久久只有这里有精品,亚洲熟女乱色综合一区
    分享

    systemctl管理腳本

     塞北de雪 2025-02-13 發布于江蘇

     

    一 介紹

    1.systemctl腳本存放在:/usr/lib/systemd/,有系統(system)和用戶(user)之分

    1)/usr/lib/systemd/system #系統服務,開機不需要登陸就能運行的程序(相當于開啟自啟)
    2)/usr/lib/systemd/user #用戶服務,需要登錄后才能運行的程序

    2./usr/lib/systemd/目錄下又存在兩種類型的文件:

    1).service # 服務unit文件
    2)
    .target # 開機級別unit

    centos7 的每一個服務以。service 結尾,一般分為3部分:【unit】、【service】、【install】字段詳細說明

    [Unit]   # 主要是服務說明
    Description=test   # 簡單描述服務
    After=network.target # 描述服務類別,表示本服務需要在network服務啟動后在啟動
    Before=xxx.service #表示需要在某些服務啟動之前啟動,After和Before字段只涉及啟動順序,不涉及依賴關系。
     
    [Service]  # 核心區域
    Type=forking     # 表示后臺運行模式。
    User=user        # 設置服務運行的用戶
    Group=user       # 設置服務運行的用戶組
    KillMode=control-group   # 定義systemd如何停止服務
    PIDFile=/usr/local/test/test.pid    # 存放PID的絕對路徑
    Restart=no        # 定義服務進程退出后,systemd的重啟方式,默認是不重啟
    ExecStart=/usr/local/test/bin/startup.sh    # 服務啟動命令,命令需要絕對路徑
    PrivateTmp=true                               # 表示給服務分配獨立的臨時空間
     
    [Install]   
    WantedBy=multi-user.target  # 多用戶
    

    1、Type類型有:

    simple(默認):#以Execstart字段啟動的進程為主進程
     
    forking:#Execstart 字段以fox()方式啟動,,此時父進程將退出,子進程將成為主進程(后臺運行),一般都設置為forking
     
    oneshot : #類似于simple,但只執行一次,systemd會等他執行完,才執行其他服務
     
    dbus: #類似于simple,但會等待D—Bus信號后啟動
     
    notify: #類似與simple ,但結束后會發出通知信號,然后systemd才啟動其他服務
     
    idle: #類似與simple,但要等到其他任務都執行完,才啟動該服務
    

    2、EnvironmentFile:指定配置文件,和連詞號組合使用,可以避免配置文件不存在的異常

    Environment:
    后面接多個不同的shell變量。
    例如:
    Environment=DATA_DIR=/data/elk
    Environment=LOG_DIR=/var/log/elasticsearch
    Environment=PID_DIR=/var/run/elasticsearch
    EnvironmentFile=-/etc/sysconfig/elasticsearch
     
    連詞號(-):在所有啟動設置之前,添加的變量字段,都可以加上連詞號
    表示抑制錯誤,即發生錯誤時,不影響其他命令的執行。
    比如EnviromentFile=-/etc/sysconfig/xxx表示即使文件不存在,也不會拋異常
    

    3、Killmode的類型

    contorl-group (默認) # 當前控制組里所有的子進程都會被殺掉
     
    process : #只殺主進程
     
    mixed: #主進程將收到SIGTERM(終止進程)信號,子進程將收到SIGKILL(無條件終止)信號
     
    none: # 沒有進程會被殺掉,只是執行服務的stop命令
    

    4、Restart類型

      no (默認):#退出后無操作
     
      on-success :#只有正常退出時(退出狀態碼為0),才會重啟
     
      on-failure: #非正常退出時,重啟,包括信號終止,和超時
     
      on-abnaomal:  #只有信號終止或超時,才會重啟
     
      on-abort : #只有在收到沒有捕捉到信號終止時,才會重啟
     
      on-watchdog: #超市退出時,才會重啟
     
      always: #不管什么退出原因,都會重啟
     
      #對于守護進程,推薦使用on-failure
    

    5、RestartSe

    表示systemd重啟服務之前,需要等待的秒數:RestartSec:30
    

    6、各種Exec*字段

    Exec*后面的命令,僅接受'指令 參數 參數..’格式,不能接受<> |&等特殊字符,很多bash語法也不支持,如果想要支持bash語法,需要設置Tyep=oneshot
     
    # ExecStart:    # 啟動服務時執行的命令
    # ExecReload:   # 重啟服務時執行的命令 
    # ExecStop:     # 停止服務時執行的命令 
    # ExecStartPre: # 啟動服務前執行的命令 
    # ExecStartPost:# 啟動服務后執行的命令 
    # ExecStopPost: # 停止服務后執行的命令
    # PrivateTmp=True #表示給服務分配獨立的臨時空間,
    # 注意:[Service]部分的啟動、重啟、停止命令全部要求使用絕對路徑,使用相對路徑則會報錯!
     
    [Service]
    Type=forking
    PIDFile=/home/developer/web/gunicorn.pid
    ExecStart=/usr/local/bin/forever start 
    ExecReload=/bin/kill -s HUP $MAINPID
    ExecStop=/bin/kill -s QUIT $MAINPID
    PrivateTmp=true
    

    7、[Install]部分是服務安裝的相關設置,可設置為多用戶的

    [Install]
    WantedBy=multi-user.target
    # WantedBy字段:
    # multi-user.target: # 表示多用戶命令行狀態,這個設置很重要
    # graphical.target: # 表示圖形用戶狀體,它依賴于multi-user.target
    

    修改配置文件以后,以754的權限保存在/usr/lib/systemd/system目錄下,需要重新加載配置文件方可生效
    $ systemctl daemon-reload

    這時就可以利用systemctl進行配置了

    首先,使用systemctl start [服務名(也是文件名)]可測試服務是否可以成功運行,如果不能運行則可以使用systemctl status [服務名(也是文件名)]查看錯誤信息和其他服務信息,然后根據報錯進行修改,直到可以start,如果不放心還可以測試restart和stop命令。

    接著,只要使用systemctl enable xxxxx就可以將所編寫的服務添加至開機啟動即可。

    二 實操

    編寫腳本如下,并且保證腳本有可執行權限

    [root@aliyun ~]# cat nginx.sh 
    #!/bin/bash
     
    . /etc/init.d/functions
    args=$1
     
    fun(){
        [ $? -eq 0 ] && action "Nginx $args is " /bin/true  || echo "Nginx $args is " /bin/false 
    }
     
    case $1 in
       start)
           netstat -lntup|grep  ":8080\b" &>/dev/null
           if [ $? -eq 0 ]
           then 
              echo "Nginx is runing..."
           else
               /usr/local/nginx/sbin/nginx
               fun
           fi
           ;;
       stop)
           /usr/local/nginx/sbin/nginx -s stop
           fun
           ;;
       reload)
           /usr/local/nginx/sbin/nginx -s reload
           fun
           ;;
      restart)
           netstat -lntup|grep  ":8800\b" &>/dev/null
           if [ $? -ne 0 ]
           then
              /usr/local/nginx/sbin/nginx
              [ $? -eq 0 ] && echo "Nginx start is ok" || echo "Nginx start is failed"
           else
              /usr/local/nginx/sbin/nginx -s stop                             
              [ $? -eq 0 ] && echo "Nginx stop is ok" || echo "Nginx stop is failed"
              sleep 2
              /usr/local/nginx/sbin/nginx 
              fun 
           fi
           ;;
       status)
           netstat -lntup|grep  ":8080\b" &>/dev/null
           if [ $? -eq 0 ]
           then
              echo "Nginx is runing ..."
           else
              echo "Nginx is not runing ..."
           fi
           ;;
        *)
            echo "Usage: $0 {start|stop|status|restart|reload}"
            exit 2
    esac
     
    [root@aliyun ~]# chmod +x nginx.sh 
    
    

    配置

    [root@aliyun ~]# cat /usr/lib/systemd/system/nginx.service 
    [Unit]
    Description=Nginx server daemon
     
    [Service]
    Type=forking
    ExecStart=/root/nginx.sh start
    ExecStop=/root/nginx.sh stop
    ExecReload=/root/nginx.sh reload
    PrivateTmp=true
     
    [Install]
    WantedBy=multi-user.target
    
    

    重新加載

    systemctl daemon-reload
    
    

    測試

    [root@aliyun ~]# systemctl start nginx
    [root@aliyun ~]# systemctl status nginx
    ● nginx.service - Nginx server daemon
       Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled)
       Active: active (running) since Mon 2020-08-24 00:10:44 CST; 1s ago
      Process: 4166 ExecStart=/root/nginx.sh start (code=exited, status=0/SUCCESS)
     Main PID: 4173 (nginx)
       CGroup: /system.slice/nginx.service
               ├─4173 nginx: master process /usr/local/nginx/sbin/nginx
               └─4175 nginx: worker process
    
    Aug 24 00:10:44 aliyun systemd[1]: Starting Nginx server daemon...
    Aug 24 00:10:44 aliyun nginx.sh[4166]: Nginx start is  [  OK  ]
    Aug 24 00:10:44 aliyun systemd[1]: Started Nginx server daemon.
    [root@aliyun ~]# systemctl reload nginx
    [root@aliyun ~]# systemctl status nginx
    ● nginx.service - Nginx server daemon
       Loaded: loaded (/usr/lib/systemd/system/nginx.service; disabled; vendor preset: disabled)
       Active: active (running) since Mon 2020-08-24 00:10:44 CST; 13s ago
      Process: 4186 ExecReload=/root/nginx.sh reload (code=exited, status=0/SUCCESS)
      Process: 4166 ExecStart=/root/nginx.sh start (code=exited, status=0/SUCCESS)
     Main PID: 4173 (nginx)
       CGroup: /system.slice/nginx.service
               ├─4173 nginx: master process /usr/local/nginx/sbin/nginx
               └─4193 nginx: worker process
    
    Aug 24 00:10:44 aliyun systemd[1]: Starting Nginx server daemon...
    Aug 24 00:10:44 aliyun nginx.sh[4166]: Nginx start is  [  OK  ]
    Aug 24 00:10:44 aliyun systemd[1]: Started Nginx server daemon.
    Aug 24 00:10:56 aliyun systemd[1]: Reloading Nginx server daemon.
    Aug 24 00:10:56 aliyun nginx.sh[4186]: Nginx reload is  [  OK  ]
    Aug 24 00:10:56 aliyun systemd[1]: Reloaded Nginx server daemon.
    [root@aliyun ~]# 
    

    三 練習

    把下述腳本sync.sh添加到systemctl

    #!/bin/bash
    
    case $1 in
    start)
    	ps -ef|grep [s]ersync &>/dev/null
    	if [ $? -eq 0 ]
    	then
    		action "sersync is running..."   /bin/true
    	else
    		/usr/local/sersync/bin/sersync -dro /usr/local/sersync/conf/confxml.xml &>/dev/null
    		[ $? -eq 0 ] && action "sersync start is " /bin/true || action "sersync start is" /bin/false
    	fi
    	;;
    stop)
    	ps -ef|grep [s]ersync &>/dev/null
    	if [ $? -eq 0 ]
    	then
    		Pid_num=$(ps -ef|grep [s]ersync|awk '{print $2}')
    		kill $Pid_num
    		ps -ef|grep [s]ersync &>/dev/null
    		[ $? -ne 0 ] && action "sersync stop is"  /bin/true  || action "sersync stop is"  /bin/false
    	else
    		action "sersync is not runing ... "  /bin/false
    	fi
    esac
    

    測試

    systemctl  daemon-reload
    systemctl  start sersync 
    systemctl  stop sersync

      本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發布,不代表本站觀點。請注意甄別內容中的聯系方式、誘導購買等信息,謹防詐騙。如發現有害或侵權內容,請點擊一鍵舉報。
      轉藏 分享 獻花(0

      0條評論

      發表

      請遵守用戶 評論公約

      類似文章 更多

      主站蜘蛛池模板: 国产永久免费高清在线观看| 在线a亚洲老鸭窝天堂| 国产精品未满十八禁止观看| 午夜福利国产精品视频| 欧美黑人XXXX性高清版| 亚洲av永久无码精品漫画 | 色欲AV伊人久久大香线蕉影院| 国产无人区码一区二区| 欧美怡春院一区二区三区| 天天日天天谢天天视2019天干| 国产欧美综合在线观看第十页| 国产乱码精品一区二区三区四川人| 鲁丝片一区二区三区免费| 亚洲乱码一卡二卡卡3卡4卡| a级国产乱理伦片在线观看al| 亚洲AV无码午夜嘿嘿嘿| 亚洲成在人线在线播放无码| 强开少妇嫩苞又嫩又紧九色| 国产日韩精品中文字幕| 成人无码视频97免费| 国产欧美日韩亚洲一区二区三区 | 孕妇特级毛片ww无码内射| 久久综合九色综合97婷婷| 久久精品久久电影免费理论片| 中文字幕在线亚洲日韩6页| 依依成人精品视频在线观看| 激情综合婷婷色五月蜜桃| 精品乱码一区二区三四五区| 又黄又爽又无遮挡免费的网站 | 夜鲁鲁鲁夜夜综合视频| 久久精品国产亚洲av天海翼| 亚洲伊人久久综合影院| 天天澡日日澡狠狠欧美老妇| 久久精品丝袜高跟鞋| 国产香蕉一区二区三区在线视频| 中文字幕永久精品国产| 精品久久人妻AV中文字幕| 日韩人妻系列无码专区| 国厂精品114福利电影免费| 久久国产免费观看精品3| 亚洲精品55夜色66夜色|