(最简单的方式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
#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