前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >centos7上systemd详解 原

centos7上systemd详解 原

作者头像
拓荒者
发布2019-04-19 11:41:11
9280
发布2019-04-19 11:41:11
举报
文章被收录于专栏:运维经验分享运维经验分享

2018.07.21 16:39* 字数 1063 阅读 291评论 0喜欢 0

CentOS 7继承了RHEL 7的新的特性,如强大的systemd, 而systemd的使用也使得以往系统服务的/etc/init.d的启动脚本的方式就此改变, 也大幅提高了系统服务的运行效率。但服务的配置和以往也发生了极大的不同,同时变的简单而易用了许多。

CentOS 7的服务systemctl脚本存放在:/usr/lib/systemd/,有系统 system 和用户 user 之分, 即:/usr/lib/systemd/system 和 /usr/lib/systemd/user

一、配置文件

这里先说明一下unit的文件位置,一般主要有三个目录:

代码语言:javascript
复制
/lib/systemd/system
/run/systemd/system
/etc/systemd/system

这三个目录的配置文件优先级依次从低到高,如果同一选项三个地方都配置了,优先级高的会覆盖优先级低的。 系统安装时,默认会将unit文件放在/lib/systemd/system目录。如果想要修改系统默认的配置,比如nginx.service,一般有两种方法:

1、在/etc/systemd/system目录下创建nginx.service文件,里面写上我们自己的配置。 在/etc/systemd/system下面创建nginx.service.d目录,在这个目录里面新建任何以.conf结尾的文件,然后写入自己的配置。推荐这种做法。

2、/run/systemd/system这个目录一般是进程在运行时动态创建unit文件的目录,一般很少修改,除非是修改程序运行时的一些参数时,即Session级别的,才在这里做修改。

二、服务配置

每一个服务以.service结尾,一般会分为3部分:[Unit]、[Service]和[Install],nginx为例,具体内容如下:

代码语言:javascript
复制
[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=/usr/local/nginx/logs/nginx.pid
ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/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 Type=simple(默认值):systemd认为该服务将立即启动,服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型 Type=forking:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求, 使用此类型启动即可。使用此启动类型应同时指定PIDFile=,以便systemd能够跟踪服务的主进程。 Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。 Type=notify:与 Type=simple 相同,但约定服务会在就绪后向 systemd 发送一个信号,这一通知的实现由 libsystemd-daemon.so 提供 Type=dbus:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。

PIDFile : pid文件路径 ExecStartPre :启动前要做什么,上文中是测试配置文件 -t ExecStart:启动 ExecReload:重载 ExecStop:停止 PrivateTmp:True表示给服务分配独立的临时空间

  • [Install] WantedBy:服务安装的用户模式,从字面上看,就是想要使用这个服务的有是谁?上文中使用的是:multi-user.target ,就是指想要使用这个服务的目录是多用户。 每一个.target实际上是链接到我们单位文件的集合,当我们执行:
代码语言:javascript
复制
systemctl enable nginx.service

就会在 /etc/systemd/system/multi-user.target.wants/ 目录下新建一个 /usr/lib/systemd/system/nginx.service 文件的链接。

四、操作示例

下面是几个最常用的service操作:

代码语言:javascript
复制
自启动
systemctl enable nginx.service

禁止自启动
systemctl disable nginx.service

启动服务
systemctl start nginx.service

停止服务
systemctl stop nginx.service

重启服务
systemctl restart nginx.service

查看Unit定义文件
systemctl cat nginx.service

编辑Unit定义文件
systemctl edit nginx.service

重新加载Unit定义文件
systemctl reload nginx.service

列出已启动的所有unit,就是已经被加载到内存中
systemctl list-units

列出系统已经安装的所有unit,包括那些没有被加载到内存中的unit
systemctl list-unit-files

查看服务的日志
journalctl -u nginx.service    # 还可以配合`-b`一起使用,只查看自本次系统启动以来的日志

查看所有target下的unit
systemctl list-unit-files --type=target

查看默认target,即默认的运行级别。对应于旧的`runlevel`命令
systemctl get-default

设置默认的target
systemctl set-default multi-user.target

查看某一target下的unit
systemctl list-dependencies multi-user.target

切换target,不属于新target的unit都会被停止
systemctl isolate multi-user.target

关机
systemctl poweroff   
 
重启
systemctl reboot       

进入rescue模式
systemctl rescue

参考资料

https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/System_Administrators_Guide/sect-Managing_Services_with_systemd-Unit_Files.html https://www.nginx.com/resources/wiki/start/topics/examples/systemd/ http://time-track.cn/systemd-introduction.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、配置文件
  • 二、服务配置
  • 三、配置项说明
  • 四、操作示例
  • 参考资料
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档