(最简单的方式nohup python xxx.py)python
-------------------------------------------------------------------------------------------------------------------linux
Python脚本开机自动运行;本帖适用于使用systemd的Linux系统,如今流行的Linux发行版都使用systemd。vim
后台服务程序是随系统自启动的,咱们只要把Python脚本配置为服务就好了。须要注意的一点是你Python脚本的启动时机,它依赖不依赖其余服务(网络链接、一些分区的挂载等等)。sublime-text
一个你要自启动的Python脚本,我使用 /home/snail/autorun.py为例。网络
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.log 2>&1
|
更改配置文件的权限:code
1
|
$ sudo chmod 644 /lib/systemd/system/autorun.service
|
1
2
|
$ sudo systemctl daemon-reload
$ sudo systemctl enable autorun.service
|
1
|
$ sudo reboot
|
1
|
$ sudo systemctl status autorun.service
|
systemctl命令是系统服务管理器指令,它实际上将 service 和 chkconfig 这两个命令组合到一块儿。
任务 | 旧指令 | 新指令 |
使某服务自动启动 | chkconfig --level 3 httpd on | 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 accept
若是仍然有问题,就多是SELinux致使的
关闭SElinux:
修改/etc/selinux/config
文件中的SELINUX=””
为disabled,而后重启。
完全关闭防火墙:
sudo systemctl status firewalld.service
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service