zoukankan      html  css  js  c++  java
  • 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
    
    [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		# 查看启动失败的服务列表
    
  • 相关阅读:
    10 给予scrapy-redis的分布式爬虫
    pandas 01 序列和数据库昂
    如何控制分布式爬虫结束
    动态导入模块
    docker
    09 scrapy中间件
    scrapy 获取settings中的内容
    session对象的cookies
    文本检测-1-MSER
    CTW1500数据集介绍
  • 原文地址:https://www.cnblogs.com/linagcheng/p/13291786.html
Copyright © 2011-2022 走看看