Home
Posts
Tag
About
使用systemctl管理服务
使用systemctl管理服务
2019-03-20 13:32:06
以nginx自定义配置为例,以```754```的权限将下方内容保存至```/usr/lib/systemd/system/nginx.service``` 启动服务: ```shell systemctl nginx start ``` `nginx.servie`文件内容 ```shell # copy to /usr/lib/systemd/system/. [Unit] Description=nginx - high performance web server Documentation=http://nginx.org/en/docs/ After=network.target remote-fs.target nss-lookup.target [Service] Type=forking PIDFile=/run/nginx.pid ExecStartPre=/usr/sbin/nginx -t -c /etc/nginx/nginx.conf ExecStart=/usr/sbin/nginx -c /etc/nginx/nginx.conf ExecReload=/bin/kill -s HUP $MAINPID ExecStop=/bin/kill -s QUIT $MAINPID PrivateTmp=true [Install] WantedBy=multi-user.target ``` --- ### 配置项说明 - ### [Unit] ```Description```: 服务的简单描述 ```Documentation``` : 服务文档 ```After```= : 依赖,仅当依赖的服务启动之后再启动自定义的服务单元 - ### [Service] ```Type``` : 启动类型simple、forking、oneshot、notify、dbus + ```simple(默认值)```:systemd认为该服务将立即启动。服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型。 + ```forking```:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可。使用此启动类型应同时指定 PIDFile=,以便systemd能够跟踪服务的主进程。 + ```oneshot```:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。 + ```notify```:与 ```simple``` 相同,但约定服务会在就绪后向 systemd 发送一个信号。这一通知的实现由 libsystemd-daemon.so 提供。 + ```dbus```:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。 ```PIDFile``` : pid文件路径 ```ExecStartPre``` :启动前要做什么,上文中是测试配置文件 -t ```ExecStart```:启动 ```ExecReload```:重载 ```ExecStop```:停止 ```PrivateTmp```:True表示给服务分配独立的临时空间 - ### [Install] ```WantedBy```:服务安装的用户模式,从字面上看,就是想要使用这个服务的有是谁?上文中使用的是:```multi-user.target``` ,就是指想要使用这个服务的目录是多用户。 [转自:Aboriginal Tribe (土著部落)](http://blog.csdn.net/younger_china/article/details/52539522)