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 # 查看啟動失敗的服務列表