[转帖]CentOS7上systemctl的使用

centos7,systemctl,使用 · 浏览次数 : 0

小编点评

**CentOS 7.x 中的 systemd 服务** **1. 原有的 service 命令与 systemctl 命令对比** - 原有的 service 命令使用 `systemctl` 命令,例如 `systemctl start network.service` 和 `systemctl stop network.service`。 - systemctl 命令则更简洁,使用 `systemctl` 命令,例如 `systemctl start network` 和 `systemctl stop network`。 **2. 原有的 chkconfig 命令与 systemctl 命令对比** - 原有的 chkconfig 命令使用 `systemctl` 命令,例如 `systemctl enable network.service` 和 `systemctl disable network.service`。 - systemctl 命令则更简洁,使用 `systemctl enable` 和 `systemctl disable` 命令,例如 `systemctl enable cups.service` 和 `systemctl disable cups.service`。 **3. 针对系统服务命令格式的详细说明** - `systemctl list-units` 命令可以列出所有启动的 service、socket、target 等类型服务。 - `systemctl is-active [unit type]` 命令可以查看服务是否运行。 - `systemctl is-enable [unit type]` 命令可以查看服务是否设置为开机启动。 **4. init 命令与 systemctl 命令对比** - `init` 命令用于重启系统,而 `systemctl` 命令用于重新启动服务。 - `systemctl poweroff` 用于关闭系统,而 `systemctl reboot` 用于重新启动系统。 **5. 设置系统运行级别** - `systemctl target0shutdown.target` 用于关闭所有服务并进入关机模式。 - `systemctl list-dependencies --reversedefault.target` 可以查看当前运行级别依赖哪些服务。 **6. 关闭网络服务** - 使用 `systemctl list-units --all | grep sshd` 命令可以列出所有与 SSH 服务相关的服务。 - 使用 `systemctl stop sshd.servicesystemctl stop sshd.socketsystemctl disable sshd.service sshd.socket` 命令关闭所有 SSH 服务。 **7. 关闭防火墙** - 使用 `systemctl stop firewalld.service` 命令关闭防火墙服务。 - 使用 `firewallCentos 7.x` 命令更改防火墙规则,将其代理给 firewalld。

正文

https://www.cnblogs.com/yeyuzhuanjia/p/14676182.html

 

CentOS 7.x开始,CentOS开始使用systemd服务来代替daemon,原来管理系统启动和管理系统服务的相关命令全部由systemctl命令来代替。

1、原来的 service 命令与 systemctl 命令对比

 

daemon命令

systemctl命令

说明

service [服务] start

systemctl start [unit type]

启动服务

service [服务] stop

systemctl stop [unit type]

停止服务

service [服务] restart

systemctl restart [unit type]

重启服务

service [服务] status

systemctl status [unit type]

查看服务状态

 

systemctl  daemon-reload

重新加载,使配置文件生效

(并不是所有服务都支持这个参数,比如network.service)

 

应用举例:

#启动网络服务

systemctl start network.service

 

#停止网络服务

systemctl stop network.service

 

#重启网络服务

systemctl restart network.service

 

#查看网络服务状态

systemctl status network.serivce

 

2、原来的chkconfig 命令与 systemctl 命令对比

2.1、设置开机启动/不启动

daemon命令

systemctl命令

说明

chkconfig [服务] on

systemctl enable [unit type]

设置服务开机启动

chkconfig [服务] off

systemctl disable [unit type]

设备服务禁止开机启动

 

应用举例:

#停止cup电源管理服务

systemctl stop cups.service

 

#禁止cups服务开机启动

systemctl disable cups.service

 

#查看cups服务状态

systemctl status cups.service

 

#重新设置cups服务开机启动

systemctl enable cups.service

 

2.2、查看系统上上所有的服务

命令格式:

systemctl [command] [–type=TYPE] [–all]

参数详解:

command - list-units:依据unit列出所有启动的unit。加上 –all 才会列出没启动的unit; - list-unit-files:依据/usr/lib/systemd/system/ 内的启动文件,列出启动文件列表

–type=TYPE - 为unit type, 主要有service, socket, target

 

应用举例:

systemctl命令

说明

systemctl

列出所有的系统服务

systemctl list-units

列出所有启动unit

systemctl list-unit-files

列出所有启动文件

systemctl list-units –type=service –all

列出所有service类型的unit

systemctl list-units –type=service –all grep cpu

列出 cpu电源管理机制的服务

systemctl list-units –type=target –all 

列出所有target

 

3、systemctl特殊的用法

systemctl命令

说明

systemctl is-active [unit type]

查看服务是否运行

systemctl is-enable [unit type]

查看服务是否设置为开机启动

systemctl mask [unit type]

注销指定服务

systemctl unmask [unit type]

取消注销指定服务

 

应用举例:

#查看网络服务是否启动

systemctl is-active network.service

 

#检查网络服务是否设置为开机启动

systemctl is-enabled network.service

 

#停止cups服务

systemctl stop cups.service

 

#注销cups服务

systemctl mask cups.service

 

#查看cups服务状态

systemctl status cups.service

 

#取消注销cups服务

systemctl unmask cups.service

 

4、init 命令与systemctl命令对比

init命令

systemctl命令

说明

init 0

systemctl poweroff

系统关机

init 6

systemctl reboot

重新启动

 

与开关机相关的其他命令:

systemctl命令

说明

systemctl suspend

进入睡眠模式

systemctl hibernate

进入休眠模式

systemctl rescue

强制进入救援模式

systemctl emergency

强制进入紧急救援模式

 

 

5、设置系统运行级别

5.1、运行级别对应表

init级别

systemctl target

0

shutdown.target

1

emergency.target

2

rescure.target

3

multi-user.target

4

5

graphical.target

6

此外还是一个getty.target用来设置tty的数量。

 

5.2、设置运行级别

命令格式:

systemctl [command] [unit.target]

参数详解:

command:

get-default :取得当前的target

set-default :设置指定的target为默认的运行级别

isolate :切换到指定的运行级别

unit.target :为5.1表中列出的运行级别

 

systemctl命令

说明

systemctl get-default

获得当前的运行级别

systemctl set-default multi-user.target

设置默认的运行级别为mulit-user

systemctl isolate multi-user.target

在不重启的情况下,切换到运行级别mulit-user下

systemctl isolate graphical.target

在不重启的情况下,切换到图形界面下

 

6、使用systemctl分析各服务之前的依赖关系

命令格式:

systemctl list-dependencies [unit] [–reverse]

–reverse是用来检查寻哪个unit使用了这个unit

 

应用举例:

#获得当前运行级别的target

[root@www ~]# systemctl get-default

multi-user.target

 

#查看当前运行级别target(mult-user)启动了哪些服务

[root@www ~]# systemctl list-dependencies

default.target

├─abrt-ccpp.service

├─abrt-oops.service

├─vsftpd.service

├─basic.target

│ ├─alsa-restore.service

│ ├─alsa-state.service

.....(中间省略).....

│ ├─sockets.target

│ │ ├─avahi-daemon.socket

│ │ ├─dbus.socket

.....(中间省略).....

│ ├─sysinit.target

│ │ ├─dev-hugepages.mount

│ │ ├─dev-mqueue.mount

.....(中间省略).....

│ └─timers.target

│   └─systemd-tmpfiles-clean.timer

├─getty.target

│ └─getty@tty1.service

└─remote-fs.target

 

#查看哪些target引用了当前运行级别的target

[root@www ~]# systemctl list-dependencies --reverse

default.target

└─graphical.target

 

7、关闭网络服务

在使用systemctl关闭网络服务时有一些特殊 需要同时关闭unit.servce和unit.socket

使用systemctl查看开启的sshd服务

[root@www system]#  systemctl list-units --all | grep sshd

sshd-keygen.service loaded inactive dead        OpenSSH Server Key Generation

sshd.service        loaded active   running     OpenSSH server daemon

sshd.socket         loaded inactive dead        OpenSSH Server Socket

 

可以看到系统同时开启了 sshd.service 和 sshd.socket , 如果只闭关了 sshd.service 那么 sshd.socket还在监听网络,在网络上有要求连接 sshd 时就会启动 sshd.service 。因此如果想完全关闭sshd服务的话,需要同时停用 sshd.service 和 sshd.socket 。

systemctl stop sshd.service

systemctl stop sshd.socket

systemctl disable sshd.service sshd.socket

 

由于centos 7.x默认没有安装net-tools,因此无法使用netstat 来查看主机开发的商品。需要通过yum安装来获得该工具包:

yum -y install net-tools

 

查看是否关闭22端口

netstat -lnp |grep sshd

 

8、关闭防火墙firewall

Centos 7.x 中取消了iptables, 用firewall取而代之。要关闭防火墙并禁止开机启动服务使用下面的命令:

systemctl stop firewalld.service

 

本文来自博客园,作者:业余砖家,转载请注明原文链接:https://www.cnblogs.com/yeyuzhuanjia/p/14676182.html

与[转帖]CentOS7上systemctl的使用相似的内容:

[转帖]CentOS7上systemctl的使用

https://www.cnblogs.com/yeyuzhuanjia/p/14676182.html CentOS 7.x开始,CentOS开始使用systemd服务来代替daemon,原来管理系统启动和管理系统服务的相关命令全部由systemctl命令来代替。 1、原来的 service 命令

[转帖]Linux命令之systemctl命令

一、systemctl命令简介 CentOS 5使用SysV init;CentOS 6使用Upstart,CentOS 7使用Systemd管理守护进程。centos7采用 systemd管理,服务独立的运行在内存中,服务响应速度快,但占用更多内存。独立服务的服务启动脚本都在目录 /usr/lib

[转帖]centos7.6编写自己的启动服务,运行systemctl后卡住了的解决方案

https://www.cnblogs.com/niway/p/15346572.html 问题:centos7.6编写自己的启动服务,运行systemctl后卡住了,表现为当我执行systemctl命令后shell阻塞在那里,没有像平时执行命令那样自动结束(只能自己按Ctrl+C强制结束),情况如

[转帖]CentOS7搭建时间服务器-chrony

操作系统:CentOS7防火墙: 关闭防火墙和selinux时间软件:chronyCentOS7我们一直用的ntp时间服务器,虽然到CentOS7上也可以装ntp。chrony与ntp都是时间同步软件,两个软件不能够同时开启,会出现时间冲突.但是由于各种问题,所以建议CentOS7使用chrony同

[转帖]Centos7升级glibc导致系统异常(无法开机)解决方法

https://www.jb51.net/article/230473.htm 目录 我使用的是centos7(理论上这个方法仅仅对centos7以及Redhat7都可以使用该方法解决问题) 注意:此方法仅针对Redhat7/Centos7以上。 出现问题原因: 在调优hbase的时候,查资料发现可

[转帖]centos7离线安装postgresql13

https://www.cnblogs.com/summer-88/p/15341918.html 在一台可以联网的centos上安装postgresql源 yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/E

[转帖]【最佳实践】瀚高数据库安全版v4.5.8安装

瀚高数据库安全版v4.5.8已发布,功能和安装方式都有所不同。下面先跟我一起安装上吧。 操作系统环境:Centos7.9,处理器:x86_64 (说明:以下每一节的命令操作,均可以复制粘贴直接执行) 1. 安装软件 将软件包上传到root用户的目录下,执行以下命令校验安装包完整性,然后执行安装: m

[转帖]在 CentOS 7 上安装并配置 Python 3.6环境

https://www.jianshu.com/p/b978e46de442 拖了很久没有更新,抱歉啦~ 今天受邀写篇如何在 CentOS 7 上配置 Python 3 环境的文章。往常我都选择直接把我早年写的一篇文章《源码编译MongoDB》丢过去,让他们看其中的源码编译 Python 那一节,不

[转帖]如何在CentOS 7上使用Barman备份,恢复和迁移PostgreSQL数据库

http://www.manongjc.com/detail/52-bdglcaimnhmjvkm.html 本文章向大家介绍如何在CentOS 7上使用Barman备份,恢复和迁移PostgreSQL数据库,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的

[转帖]CentOS 7 下用 firewall-cmd / iptables 实现 NAT 转发供内网服务器联网

https://www.cnblogs.com/hope250/p/8033818.html 自从用 HAProxy 对服务器做了负载均衡以后,感觉后端服务器真的没必要再配置并占用公网IP资源。而且由于托管服务器的公网 IP 资源是固定的,想上 Keepalived 的话,需要挤出来 3 个公网 I