Ubuntu自啟動服務腳本


ubuntu自啟動服務腳本

參考鏈接:https://blog.csdn.net/qq_29663071/article/details/80814081

1、創建一個service文件
進入/etc/systemd/system/,創建一個my.service文件,內容如下

[Unit]
Description=just for test                    這里填簡介
After=BBB.service XXX.service  AAA.service   這里填上你這個腳本所需要的前置service,都在/etc/systemd/system/下
Wants=network-online.target

[Service]
WorkingDirectory=/home/up/VulScanWeb/semf	# 項目目錄
ExecStart=/home/up/VulScanWeb/semf/start.sh			# 這里填sh文件路徑,比如這里運行了這個my.sh,后面也可以跟參數,比如 -D -I
Type=simple
Restart=always
TimeoutSec=infinity
User=up        # 務必修改User為系統對應的user

[Install]
WantedBy=multi-user.target
[Unit]

Description : 服務的簡單描述

Documentation : 服務文檔

Before、After:定義啟動順序。Before=xxx.service,代表本服務在xxx.service啟動之前啟動。After=xxx.service,代表本服務在xxx.service之后啟動

Requires:這個單元啟動了,它需要的單元也會被啟動;它需要的單元被停止了,這個單元也停止了

Wants:推薦使用。這個單元啟動了,它需要的單元也會被啟動;它需要的單元被停止了,對本單元沒有影響

[Service]

Type=simple(默認值):systemd認為該服務將立即啟動。服務進程不會fork。如果該服務要啟動其他服務,不要使用此類型啟動,除非該服務是socket激活型

Type=forking:systemd認為當該服務進程fork,且父進程退出后服務啟動成功。對於常規的守護進程(daemon),除非你確定此啟動方式無法滿足需求,使用此類型啟動即可。使用此啟動類型應同時指定 PIDFile=,以便systemd能夠跟蹤服務的主進程

Type=oneshot:這一選項適用於只執行一項任務、隨后立即退出的服務。可能需要同時設置 RemainAfterExit=yes 使得 systemd 在服務進程退出之后仍然認為服務處於激活狀態

Type=notify:與 Type=simple 相同,但約定服務會在就緒后向 systemd 發送一個信號。這一通知的實現由 libsystemd-daemon.so 提供

Type=dbus:若以此方式啟動,當指定的 BusName 出現在DBus系統總線上時,systemd認為服務就緒

Type=idle: systemd會等待所有任務(Jobs)處理完成后,才開始執行idle類型的單元。除此之外,其他行為和Type=simple 類似

PIDFile:pid文件路徑

ExecStart:指定啟動單元的命令或者腳本,ExecStartPre和ExecStartPost節指定在ExecStart之前或者之后用戶自定義執行的腳本。Type=oneshot允許指定多個希望順序執行的用戶自定義命令

ExecReload:指定單元停止時執行的命令或者腳本

ExecStop:指定單元停止時執行的命令或者腳本

PrivateTmp:True表示給服務分配獨立的臨時空間

Restart:這個選項如果被允許,服務重啟的時候進程會退出,會通過systemctl命令執行清除並重啟的操作

RemainAfterExit:如果設置這個選擇為真,服務會被認為是在激活狀態,即使所以的進程已經退出,默認的值為假,這個選項只有在Type=oneshot時需要被配置

[Install]

Alias:為單元提供一個空間分離的附加名字

RequiredBy:單元被允許運行需要的一系列依賴單元,RequiredBy列表從Require獲得依賴信息

WantBy:單元被允許運行需要的弱依賴性單元,Wantby從Want列表獲得依賴信息

Also:指出和單元一起安裝或者被協助的單元

DefaultInstance:實例單元的限制,這個選項指定如果單元被允許運行默認的實例

2.創建sh文件

進入項目中,創建start.sh文件

#! /bin/bash

cd /home/up/VulScanWeb/semf		# 進入項目目錄
sudo python3 manage.py runserver 0.0.0.0:8000 >> logs/django_source.log 2>&1    # 啟動項目

3.啟動服務

journalctl -fp err     # 查看錯誤日志
journalctl -ax 	 # 查看日志
journalctl -f -u xxx.service   # 查看日志

systemctl daemon-reload		# 重載刷新配置
sytemctl start xxx.service
systemctl status xxx.service
systemctl stop xxx.service
systemctl restart xxx.service

systemctl enable xxx.service   # 設置為開機自啟
systemctl disable xxx.service		# 禁用開機自啟
systemctl is-enabled xxx.service		# 查看是否開機自啟

systemctl list-unit-files|grep enabled		# 查看已啟動的服務列表

systemctl --failed		# 查看啟動失敗的服務列表


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM