Fedora的systemctl命令详解 & Fedora配置IP地址/DNS/Networking

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

demaon 命令 vs systemctl 命令

# 此处是命令对比 分别对比 service命令 和 systemctl 在启动、停止、重启服务时的差别
service [服务] start      systemctl start [unit type]    启动服务
service [服务] stop       systemctl stop [unit type]    停止服务
service [服务] restart    systemctl restart [unit type]    重启服务

此外还有二个systemctl参数没有与service命令参数对应

status:参数来查看服务运行情况
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-enable 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    无

PS:此外还是一个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]  

PS:–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
│ └─[email protected]
└─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 。

$ sudo systemctl stop sshd.service
$ sudo systemctl stop sshd.socket
$ sudo 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

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

$ sudo systemctl stop firewalld.service
$ sudo systemctl disable firewalld.service

另附:Fedora配置IPAddress/网络连接配置

# Fedora设置IP地址
$ ifconfig -a

# 找到你要Fedora 网络使用的网卡
vi /etc/sysconfig/network-scripts/ifcfg-eth0
# Intel Corporation 82801BA/BAM/CA/CAM Ethernet Controller
DEVICE=eth0
BOOTPROTO=static
#BROADCAST=59.188.15.255
HWADDR=00:02:A5:F5:80:23
IPADDR=59.188.15.117
NETMASK=255.255.255.240
#NETWORK=59.188.15.0
ONBOOT=yes


...


# Fedora网络设置网关地址
vi /etc/sysconfig/network
NETWORKING=yes
HOSTNAME=localhost.localdomain
GATEWAY=192.168.32.1

 
# Fedora 网络设置DNS 地址 
vi /etc/resolv.conf
nameserver  172.19.30.63
nameserver  172.19.30.64
search localdomain


...


# OK设置完成后重启network
$ /etc/init.d/network restart 

# virtualbox下linux
# 请检查有没有设置开机启动网络,默认是没有开启的。

$ vi /etc/sysconfig/network-scripts/ifcfg-eth0
ONBOOT=yes

# 这里ONBOOT设置成YES,其他如IP、网关、DNS都无需设置开启DHCP都会自动获取!
# 固定ip设置 
$ vim /etc/sysconfig/network-scripts/ifcfg-enp0s3 :
TYPE=Ethernet
BOOTPROTO=static   #dhcp 换成static
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
NAME=enp0s3
UUID=2df00015-7c45-4385-ac8c-facab831641e
DEVICE=enp0s3
ONBOOT=yes
DNS1=192.168.1.1     #和宿主机一样
IPADDR=192.168.1.252  
NETMASK=255.255.255.0
#和宿主机一样
GATEWAY=192.168.1.1
#和宿主机一样

 
参考资料:

转载于: https://blog.csdn.net/u012486840/article/details/53161574 (Author : somnus_小凯

猜你喜欢

转载自blog.csdn.net/Aria_Miazzy/article/details/84572626