linux将脚本设为服务,Linux下设置python脚本文件为服务

本文介绍了在使用systemd的Linux系统中如何让Python脚本开机自动运行。通过创建Systemd服务单元文件,并设置启动时机,确保脚本在系统多用户环境加载完毕后运行。详细步骤包括编写服务配置文件、修改文件权限、使服务生效、重启系统以及查看服务状态。此外,还提到了脚本输出重定向和防火墙设置。
摘要由CSDN通过智能技术生成

(最简单的方式nohup python xxx.py)python

-------------------------------------------------------------------------------------------------------------------linux

Python脚本开机自动运行;本帖适用于使用systemd的Linux系统,如今流行的Linux发行版都使用systemd。vim

后台服务程序是随系统自启动的,咱们只要把Python脚本配置为服务就好了。须要注意的一点是你Python脚本的启动时机,它依赖不依赖其余服务(网络链接、一些分区的挂载等等)。sublime-text

#1 Python脚本

一个你要自启动的Python脚本,我使用 /home/snail/autorun.py为例。网络

#2 建立Unit配置文件

1

$sudo vim/lib/systemd/system/autorun.service

写入以下内容:tcp

1

2

3

4

5

6

7

8

9

10

[Unit]

Description=Test Service

After=multi-user.target

[Service]

Type=idle

ExecStart=/usr/bin/python/home/snail/autorun.py

[Install]

WantedBy=multi-user.target

上面定义了一个叫 Test Service 的服务,它在multi-user环境起来以后运行;ExecStart参数指定咱们要运行的程序;idle确保脚本在其余东西加载完成以后运行,它的默认值是simple。spa

注意使用绝对路径。.net

为了得到脚本的输出信息,咱们能够重定向到文件:rest

1

ExecStart=/usr/bin/python/home/snail/autorun.py>/home/snail/autorun.log2>&1

更改配置文件的权限:code

1

$sudo chmod644/lib/systemd/system/autorun.service

#3 使配置文件生效

1

2

$sudo systemctl daemon-reload

$sudo systemctl enable autorun.service

#4 重启

1

$sudo reboot

#5 查看服务状态

1

$sudo systemctl status autorun.service

0165e33960cf4e1990169a29.html

0165e33960cf4e1990169a29.html

#6 服务操做命令

systemctl命令是系统服务管理器指令,它实际上将

任务

旧指令

新指令

使某服务自动启动

chkconfig --level 3

systemctl enable httpd.service

使某服务不自动启动

chkconfig --level 3 httpd off

systemctl disable httpd.service

检查服务状态

service httpd status

systemctl status httpd.service (服务详细信息) systemctl is-active httpd.service (仅显示是否 Active)

显示全部已启动的服务

chkconfig --list

systemctl list-units --type=service

启动某服务

service httpd start

systemctl start httpd.service

中止某服务

service httpd stop

systemctl stop httpd.service

重启某服务

service httpd restart

systemctl restart httpd.service

实例

1.启动nfs服务

systemctl start nfs-server.service

2.设置开机自启动

systemctl enable nfs-server.service

3.中止开机自启动

systemctl disable nfs-server.service

4.查看服务当前状态

systemctl status nfs-server.service

5.从新启动某服务

systemctl restart nfs-server.service

6.查看全部已启动的服务

systemctl list -units --type=service

开启防火墙22端口

iptables -I INPUT -p tcp --dport 22 -j

若是仍然有问题,就多是SELinux致使的

关闭SElinux:

修改/etc/selinux/config文件中的SELINUX=””为disabled,而后重启。

完全关闭防火墙:

sudo systemctl status firewalld.service

sudo systemctl stop firewalld.service

sudo systemctl disable firewalld.service

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值