Ubuntu systemd自定义服务因python脚本而失败

时间:2019-02-23 09:56:25

标签: python ubuntu daemon systemd

想在Ubuntu中获得有关systemd守护程序服务的帮助。我有一个编写的Python脚本来禁用Dell XPS上的触摸屏,这更多的是问题而不是有用的功能。该脚本有效,但是我不想一直启动它,这就是为什么我想到编写服务文件并在启动时系统地为我启动它的原因。

我遇到的问题是“((代码=已退出,状态= 1 /失败)”)。这是我的第一次,在尝试此操作之前,我做了一些研究,但是,我现在还无法弄清楚。任何想法将不胜感激。

这是“ systemctl status disable-ts.service输出:

● disable-ts.service - Disable TouchScreen
  Loaded: loaded (/etc/systemd/system/disable-ts.service; enabled; vendor 
  preset: enabled)
  Active: failed (Result: exit-code) since Sat 2019-02-23 01:31:27 PST; 
  6min ago
  Process: 2667 ExecStart=/usr/bin/python disable-ts.py 
 (code=exited,status=1/FAILURE)

 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: disable-ts.service: Service 
 hold-off time over, schedul
 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: disable-ts.service: 
 Scheduled restart job, restart coun
 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: Stopped Disable TouchScreen.
 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: disable-ts.service: Start 
 request repeated too quickly.
 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: disable-ts.service: Failed 
 with result 'exit-code'.
 Feb 23 01:31:27 roman-XPS-15-9560 systemd[1]: Failed to start Disable 
 TouchScreen.

这是服务文件本身:

[Unit]
Description=Disable TouchScreen
After=multi-user.target

[Service]
User=roman
Type=forking
WorkingDirectory=/home/roman/Python-Scripts/
ExecStart=/usr/bin/python disable-ts.py
Restart=always

[Install]
WantedBy=multi-user.target

创建此代码后,我确实运行了:

sudo systemctl daemon-reload
sudo systemctl enable disable-ts.service
sudo systemctl start disable-ts.service

1 个答案:

答案 0 :(得分:0)

今天我自己遇到了这个确切的问题,除了我使用'simple'作为类型,并且没有指定用户或工作目录外,几乎完全相同的设置。添加工作目录对我有用。