简介RHEL7上的Systemd

Abstract: Systemd 有争议,但是Fedora,SFedora,SUSE,Rhel 都逐渐投向了systemd。都逐渐投向了systemd。 我们将会学习使用systemd 控制系统启动systemd。 我们将会学习使用systemd 控制系统启动,管理服务,查看日志。 我们将会学习使用systemd 控制系统启动,管理服务,查看日志 我们将会学习使用systemd 控制系统启动,管理服务,查看日志我们将会学习使用systemd 控制系统启动,管理服务,查看日志systemd 控制系统启动,管理服务,查看日志控制系统启动,管理服务,查看日志

“SystemD 入门”

Systemd 简介:

systemd 是由Lennart Poettering带头开发,并在LGPL 2.1及其后续版本许可证下开源发布。其开发目标是提供更优秀的框架以表示系统服务间的依赖关系,并依此实现系统初始化时服务的并行启动,同时达到降低Shell的系统开销的效果,最终代替现在常用的System V与BSD风格init程序。(来自维基百科)

Systemd 存在争议,但是Fedora,Suse,Rhel 都逐渐投向了systemd,本文将在Rhel 7 上使用systemd,带领读者学习使用systemd 控制系统启动,查看日志,管理服务。

系统启动:

我们首先来回忆下过去,/sbin/init 作为PID 为1的进程首先启动,然后fork (clone)其他的进程,按照/etc/inittab里面的设置选择runlevel, 并从/etc/rc* /etc/init.d/ 下面选择相应的启动脚本来启动服务。而现在PID 为1的进程变成了sytemd ,(PID 0是内核进程)在我的机器上则显示为:

[root@22062 ~]# ps -ef

UID PID PPID C STIME TTY TIME CMD

root 1 0 0 Jan14 ? 00:01:51 /usr/lib/systemd/systemd --system --deserialize 17

由systemd来spawn其他的进程。

而Runlevel 则变成了 Target:

graphical.target=5

multiuser.target=3

下面是一些常用的的命令:

查看default target: systemctl get-default

修改default target: systemctl set-default []

实时修改:systemctl isolate []

查看启动时间:systemd-analyze 

查看单项任务启动的时间开销: systemd-analyze blame

查看任务之间的依赖关系: systemctl list-dependencies

(注:/etc/inittab 不再使用,为向上兼容保留了runlevel5.target,runlevel3.target)

管理服务:

在以前,默认的启动脚本都放在/etc/init.d /etc/rc*下面。

Systemd 使用Unit file 来控制服务。

控制文件: /usr/lib/systemd/system

控制文件: /etc/systemd/system

运行时数据: /run/systemd

(注:/etc 目录下的文件具有更高优先级)

我在这台机器上装了HTTPD,我们来看一下HTTPD服务的状态。

[root@22062 ~]# systemctl status httpd

httpd.service - The Apache HTTP Server

Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled)

Active: active (running) since Wed 2015-01-21 03:46:34 EST; 4 days ago

Process: 18544 ExecReload=/usr/sbin/httpd $OPTIONS -k graceful (code=exited, status=0/SUCCESS)

Main PID: 10701 (httpd)

Status: "Total requests: 0; Current requests/sec: 0; Current traffic: 0 B/sec"

CGroup: /system.slice/httpd.service

├─10701 /usr/sbin/httpd -DFOREGROUND

├─18556 /usr/sbin/httpd -DFOREGROUND

├─18557 /usr/sbin/httpd -DFOREGROUND

├─18558 /usr/sbin/httpd -DFOREGROUND

├─18559 /usr/sbin/httpd -DFOREGROUND

└─18560 /usr/sbin/httpd -DFOREGROUND

SystemD默认我们这里输入都是Service,所以

systemctl status httpd 等同于 systemctl status httpd.service , Rhel 7 会把service httpd status 重定向到 systemctl status httpd.

关闭httpd服务:systemctl stop httpd

systemctl disable httpd ( 等同于以前的chkconfig httpd off)

重启/重新加载:systemctl restart httpd / systemctl reload httpd

查看httpd 服务是否是自启动的:systemctl is-enable httpd

查看httpd 是否启动: systemctl is-active httpd

查看httpd 的状态: systemctl status httpd

查看所有服务的状态:systemctl

以树状方式查看服务:systemd-cgls 

systemd-cgls 给出的树状结构非常具体,可以看到Cgroup ,服务,进程之间的层级)

在这里,我省略了一些输出。 (注:slice 并不是服务的容器)

└─system.slice

├─httpd.service

│ ├─10701 /usr/sbin/httpd -DFOREGROUND

│ ├─18556 /usr/sbin/httpd -DFOREGROUND

│ ├─18557 /usr/sbin/httpd -DFOREGROUND

│ ├─18558 /usr/sbin/httpd -DFOREGROUND

│ ├─18559 /usr/sbin/httpd -DFOREGROUND

│ └─18560 /usr/sbin/httpd -DFOREGROUND

控制文件:

下面我们来看httpd的控制文件,这个文件是软件安装时自动生成的,我们也可以在/etc/systemd/system/再生成一个httpd.service 文件,那么/lib/systemd/system/下的同名文件内容将会被覆盖。

[root@22062 ~]# cat /lib/systemd/system/httpd.service 

[Unit]

Description=The Apache HTTP Server

After=network.target remote-fs.target nss-lookup.target

[Service]

Type=notify

EnvironmentFile=/etc/sysconfig/httpd

ExecStart=/usr/sbin/httpd $OPTIONS -DFOREGROUND

ExecReload=/usr/sbin/httpd $OPTIONS -k graceful

ExecStop=/bin/kill -WINCH ${MAINPID}

# We want systemd to give httpd some time to finish gracefully, but still want

# it to kill httpd after TimeoutStopSec if something went wrong during the

# graceful stop. Normally, Systemd sends SIGTERM signal right after the

# ExecStop, which would kill httpd. We are sending useless SIGCONT here to give

# httpd time to finish.

KillSignal=SIGCONT

PrivateTmp=true

[Install]

WantedBy=multi-user.target

停止服务: 

systemctl stop httpd 或者 systemctl kill httpd 

这两个命令都能停止服务,但实现过程不同。

kill 是直接发送SIGTERM 给这个Cgroup,而stop 则是按照httpd 这个Unit的配置,ExecStop=/bin/kill -WINCH ${MAINPID}是stop 真正调用的命令。

查看日志:

在Systemd 内部它提供了一个日志,该日志会记录syslog,Kernel log,boot messages.

你可以把他当作一个syslog/rsyslog 的替代品。

简单的输入journalctl 就能查看日志。日志保存在 /run/systemd/journal/

Systemd 小结:

本文仅仅是systemd入门知识,在Rhel 7上做了些简单的实验。

Systemd 的引入是很大的变化,体现在并发启动,cgroup管理服务,对于资源的管理, 对于容器的管理,systemd 有很多内容值得挖掘。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/15673.html