对systemV和systemd的简单理解(服务方面)
在CentOS7(RHEL7)以后,服务从原来的由systemV管理机制升级到了systemd。
在sysV中,所有的服务脚本都放在/etc/rc.d/init.d/中,可以使用/etc/rc.d/init.d/daemon [start|stop|restart|reload|status]方式来管理服务,默认的运行级别在/etc/inittab文件中定义,当系统以某个运行级别启动时,会运行/etc/rc.d/rcN.d/(其中N范围为0~6)目录中所有的脚本,而这些脚本的命名都是Knnxxxxx或Snnxxxxx,其中S表示系统启动时调用,K表示系统终止时调用,nn是00~99的数字,数字的大小决定了脚本运行的顺序,最后的xxxxx为脚本的名称(长度任意),这些目录里的文件都是指向init.d目录中脚本的软连接,因为各个运行级别的所需的服务可能存在交集,所以这样能节省硬盘使用空间。
在sysV中,服务被分成两大类,一类是可独立运行的服务,另一类是受xinetd管理的服务,而xinetd本身是一个独立运行的服务,用来负责管理一些不常用的服务,当这些服务需要被使用时,由xinetd来唤醒它们,当服务使用完后,这些服务会被结束以减少系统资源的占用。
在sysV中,定义了6个运行级别,分别是:
runlevel0 = 关机
runlevel1 = 单用户模式,仅root
runlevel2 = 带网络的单用户模式
runlevel3 = 多用户模式,字符界面,标准模式
runlevel4 = 保留
runlevel5 = 多用户模式,图形界面,X11(X Window)
runlevel6 = 重启
上文中提到的文件和目录的截图:(RHEL7)
/etc/inittab:
/etc/rc.d/:(rc.local是一个脚本文件,里面定义了用户自定义启动的程序)
/etc/rc.d/rc.local:
/etc/rc.d/init.d/:(文件functions定义了很多函数,供给本目录里的脚本调用,而文件README是一个说明文件,主要说明“现在的服务由systemd管理,不再推荐使用这些脚本”,剩下的文件都是对应服务的脚本文件)
/etc/rc.d/rc3.d/:
在systemd中,所有的服务脚本都称为unit,主要分成6类:.service, .socket, .target, .path, snapshot, .timer,它们都存放在/usr/lib/systemd/system/目录中。
在systemd中,统一采用systemctl命令来管理所有的服务,主要用法:
systemctl [start|stop|restart|reload|status|is-active|is-enable|enable|disable|mask|umask] 服务名.类型 (当服务为servce类型时可以省略类型,如atd.service可以简写为atd,其他的类型不能省略,如talnet.socket)
systemclt set-default|get-default|isolate xxxxx.target 设置默认运行级别|获取当前的默认运行级别|不重启切换当前环境 (什么是环境呢,target类型的服务都为环境,当运行或切换(需要使用isolate而不能使用start)一个环境时往往会伴随着启动很多其他的服务用以支持这个环境,最常见的环境就是字符界面和图形界面,比如想从现在的字符界面临时切换到图形界面,使用systemctl isolate graphical.tatget)
在systemd中,运行级别由/etc/systemd/system/default.target定义,这个文件本身是一个软连接,如果它指向graphical.targer那么默认的运行级别就是图形界面。
在systemd中,为了向下兼容也提供了一些target来映射sysV中的运行级别,见下图,
会发现,有一些以.wants结尾的目录,上文已经说过了环境的变化往往会伴随着很多其他服务,而wants目录就是当target类型的服务切换之后自动运行的其他服务。
利用systemctl查看服务:
systemctl 列出所有已启动的服务
systemctl list-units 同上
systemctl list-units --all 列出所有服务,包括没启动的
systemctl list-unit-files 列出/usr/lib/systemd/system/目录内所有的服务文件
systemctl list-units --type=service --all 列出所有service类型的服务,其中--type的取值还可以是target,socket等等
systemctl list-units --type=service --all|grep -i cpu 列出所有和cpu相关的服务
利用systemctl快速改变环境:
systemctl poweroff 关机(相当于systemctl isolate poweroff.target)
systemctl reboot 重启
systemctl suspend 暂停/睡眠,将系统数据写入内存,同时将大部分硬件关闭,等待唤醒(相当于Windows下的睡眠)
systemctl hibernate 休眠,将系统数据写入硬盘,然后关机
systemctl rescue 进入救援模式
systemctl emergency 进入紧急模式,比救援模式更强更彻底
对systemV和systemd的简单理解(服务方面)的更多相关文章
- mDNS原理的简单理解——每个进入局域网的主机,如果开启了mDNS服务的话,都会向局域网内的所有主机组播一个消息,我是谁,和我的IP地址是多少。然后其他也有该服务的主机就会响应,也会告诉你,它是谁,它的IP地址是多少
MDNS协议介绍 mDNS multicast DNS , 使用5353端口,组播地址 224.0.0.251.在一个没有常规DNS服务器的小型网络内,可以使用mDNS来实现类似DNS的编程接口.包格 ...
- 简单理解Struts2中拦截器与过滤器的区别及执行顺序
简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...
- [转]简单理解Socket
简单理解Socket 转自 http://www.cnblogs.com/dolphinX/p/3460545.html 题外话 前几天和朋友聊天,朋友问我怎么最近不写博客了,一个是因为最近在忙着公 ...
- 【阿里云产品公测】简单日志服务SLS使用评测 + 教程
[阿里云产品公测]简单日志服务SLS使用评测 + 教程 评测介绍 被测产品: 简单日志服务SLS 评测环境: 阿里云基础ECS x2(1核, 512M, 1M) 操作系统: CentOS 6.5 x6 ...
- [svc]简单理解什么是rpc调用?跟restapi有何区别?
什么是rpc调用 restapi调用方式是对数据的crud. 常见的我们写flash写个api,或者借助django drf写个标准的resetapi,一个url可以借助httpget post pu ...
- 简单理解Zookeeper的Leader选举【转】
Leader选举是保证分布式数据一致性的关键所在.Leader选举分为Zookeeper集群初始化启动时选举和Zookeeper集群运行期间Leader重新选举两种情况.在讲解Leader选举前先了解 ...
- 简单理解php的socket连接
socket建立套接的过程图: 首先了解socket 几个主要函数: socket的关键函数1: socket_create($net参数1,$stream参数2,$protocol参数3) 作用:创 ...
- 【原创】分布式之数据库和缓存双写一致性方案解析(三) 前端面试送命题(二)-callback,promise,generator,async-await JS的进阶技巧 前端面试送命题(一)-JS三座大山 Nodejs的运行原理-科普篇 优化设计提高sql类数据库的性能 简单理解token机制
[原创]分布式之数据库和缓存双写一致性方案解析(三) 正文 博主本来觉得,<分布式之数据库和缓存双写一致性方案解析>,一文已经十分清晰.然而这一两天,有人在微信上私聊我,觉得应该要采用 ...
- input屏蔽历史记录 ;function($,undefined) 前面的分号是什么用处 JSON 和 JSONP 两兄弟 document.body.scrollTop与document.documentElement.scrollTop兼容 URL中的# 网站性能优化 前端必知的ajax 简单理解同步与异步 那些年,我们被耍过的bug——has
input屏蔽历史记录 设置input的扩展属性autocomplete 为off即可 ;function($,undefined) 前面的分号是什么用处 ;(function($){$.ex ...
随机推荐
- 基于Python和Xtrbackup的自动化备份与还原实现
xtrabackup是一个MySQL备份还原的常用工具,实际使用过程应该都是shell或者python封装的自动化脚本,尤其是备份.对还原来说,对于基于完整和增量备份的还原,还原差异备份需要指定增量备 ...
- spring+cxf No bean named 'cxf' available
最近项目中需要用到webservice,在spring中集成cxf时一直报错: 严重: StandardWrapper.Throwable org.springframework.beans.fact ...
- 快速查看本地IP地址
1. 新建Windows批处理文件(*.bat) @echo off echo 本机IP ipconfig|find "IPv4" echo. echo 电脑名 hostname ...
- Go语言系列:(2)go get 命令介绍
Go语言的代码被托管于 Github.com 网站,该网站是基于 Git 代码管理工具的,很多有名的项目都在该网站托管代码.其他类似的托管网站还有 code.google.com.bitbucket. ...
- Linux系统iptables与firewalld防火墙
iptables iptables服务用于处理或过滤流量的策略条目(规则),多条规则可以组成一个规则链,而规则链则依据数据包处理位置的不同进行分类. 在进行路由选择前处理数据包(PREROUTING) ...
- nodejs攻略——第一章 配置
nodejs这玩意吧,我也是心血来潮的学习,所以啊.看这篇文章之前请大家有以下技能,如果没有..我不确定你能看得懂,毕竟我文采水平实在有限. 前置技能要求: c#或java 熟练+ JavaScrip ...
- 在windows桌面上创建一个文件夹
用dos命令创建 md [文件路径][文件名] C:\Users\admin>md C:\Users\admin\desktop\test 刷新一下桌面,就可以看见桌面上创建了一个名为test ...
- 对numpy.meshgrid()理解
一句话解释numpy.meshgrid()——生成网格点坐标矩阵.关键词:网格点,坐标矩阵 网格点是什么?坐标矩阵又是什么鬼?看个图就明白了: 图中,每个交叉点都是网格点,描述这些网格点的坐标的矩阵, ...
- Java 并发编程 | 线程池详解
原文: https://chenmingyu.top/concurrent-threadpool/ 线程池 线程池用来处理异步任务或者并发执行的任务 优点: 重复利用已创建的线程,减少创建和销毁线程造 ...
- 创建多进程之multiprocess包中的process模块
创建多进程之multiprocess包中的process模块 1.process模块是一个创建进程的模块 Process([group [, target [, name [, args [, kwa ...