systemd和systemctl

systemd:

     POTS–>boot Sequence(BIOS)–>Bootloader(MBR)–>kernel(ramdisk)–>rootfs(swithroot)–>/sbin/init     

          init:

               CentOS 5 :SysV init

               CentOS 6:UPstart

               CentOS 7:systemd

systemd的新特性:

          系统引导时实现服务并行启动;

          按需激活进程;

          系统状态快照;

          基于依赖关系定义服务控制逻辑;

        同时采用socket式与D-bus总线式激活服务

核心概念:unit

          unit由其相关配置文件进行标识,识别和配置;文件中主要包含了系统服务,监听的socket,保存的快照以及其他的与init相关的信息;

这些配置文件主要保存在/usr/lib/systemd/system,/run/systemd/system,/etc/systemd/system

配置文件:

    /usr/lib/systemd/system:每个服务最主要的启动脚本设置,类似于之前的/etc/init.d/

    /run/systemd/system:系统执行过程中所产生的服务脚本,比上面目录优先运行

    /etc/systemd/system:管理员建立的执行脚本,类似与/etc/rc.d/rcN.d/Sxx类的功能,比上面目录优先运行

        

unit的常见类型:

     Service unit:文件扩展名为.service,用于定义系统服务

     Target unit:文件扩展名为.target,用于模拟实现“运行级别”

     Device unit:文件扩展名为.device,用于定义内核识别的设备;

     Mount unit:文件扩展名.mount,用于定义文件系统挂载点;

     Socket unit:文件扩展名.socket,用于标识进程间通信用到的socket文件;

     Snapshot unit:文件扩展名.snapshot:用于管理系统快照

     Swap unit:文件扩展名.swap:用于标识管理swap设备

     Automount unit:.automount:文件系统自动挂载点设置

     Path unit:.path,用于定义文件系统的一文件或目录;

关键特性:

    基于socket的激活机制:socket与程序分离;

     基于bus的激活机制;

     基于device的激活机制;

     基于path的激活机制;

     系统快照:保存个unit的当前状态信息于持久存储设备中;

     向后兼容sysv init 脚本;

       /etc/init.d/

不兼容:

     systemctl的命令是固定不变的;

     非由systemd启动的服务,systemctl无法与之通信

管理系统服务:

    CentOS 7:service类型的unit文件;  

        

    systemctl命令:

           systemctl – Control the systemd system and service manager 

      格式为:systemctl [OPTIONS…] COMMAND [NAME…]

命令对比:

     启动:service NAME start ===》systemctl start NAME.Sservice

    停止:service NAME stop ===》systemctl stop NAME.Sservice

    重启:service NAME restart===》systemctl restart NAME.Sservice

    状态:service NAME status===》systemctl status NAME.Sservice

blob.png

    条件时重启:service NAME condrestart ===>systemctl  try-restart NAME.service

         centos 7. 如果服务此前是启动的,就重启,如果没有启动就不管了;

         centos 6. 如果服务此前是启动的,就重启,如果没有启动就将它启动

    重载或重启服务:systemctl reload-or-restart  NAME.service

        centos 7  如果没服务支持重载就重载此服务,如果不支持,就重启此服务

    重载或条件式重启服务:systemctl reload-or-try-restart  NAME.service

        centos 7  如果没服务支持重载就重载此服务,如果不支持,就尝试重启此服务

    查看某服务当前激活与否的状态:systemctl is-active  NAME.service

 blob.png  

    查看所有已激活的服务:chkconfig –list ====>systemctl list-units –type service(简写为-t)

 blob.png

    查看所有的服务:chkconfig –list ====>systemctl list-units –type service –all (简写为-t,-a)

 blob.png   

   设置服务开机自启:chkoncfig NAME on ====>systemctl enable  NAME.service

 blob.png

    禁止服务开机自启:chkoncfig NAME off ====>systemctl disable  NAME.service

 blob.png

    查看某服务是否能开机自启:chkconfig –list NAME ===>systemctl  is-enabled NAME.service

 blob.png

    禁止某服务设定为开机自启:systenctl  mask  NAME.service

    取消禁止某服务设定为开机自启:systenctl  unmask  NAME.service

 blob.png

    查看服务的依赖关系:systemctl  list-dependencies NAME.service

 blob.png

    查看所有服务的开机自启状态:systemctl list-unit-files –type service 

 blob.png

    杀掉进程:

        systemctl kill 进程名 

    列出失败的服务

 blob.png

服务状态:

systemctl list-units –type service –all 显示状态    

blob.png

loaded:Unit配置文件已处理

active(running):一次或多次持续处理的运行

active(exited):成功完成一次性的配置

active(running):运行中,等待一个事件

inactive:不允许

enbled:开机启动

disabled:开机不启动

static:开机不启动,但可被另一个启用的服务激活

管理target units:

    unit配置文件:.target

    ls /usr/lib/systemd/system/*.target 

blob.png

 systemctl list-unit-files –type target –all

blob.png 

  查看所有级别:systemcl  list-units –type target –all

blob.png

   运行级别:

        0====> runlever0.target,poweroff.target

        1====> runlever1.target ,recuse.target

        2====> runlever2.target, multi-user.target

        3====> runlever3.target, multi-user.target

        4====> runlever4.target, multi-user.target

        5====> runlever4.target , graphical.target

        6====> runlever4.target,reboot.target

     级别切换: init N ====>systemctl  isolate NAME.target

        例如:切换到图形界面 :systemctl  isolate graphical.target

     查看级别:runlevel  who -r ===>systemcl  list-units –type target

blob.png 

查看所有级别:systemcl  list-units –type target –all

blob.png

注: 只有/lib/systemd/system/*.target 文件中AllowIsolate=yes  才能切换( 修改文件需执行systemctl daemon-reload 才能生效)

    获取默认运行级别:systemctl  get-default

    修改默认运行级别:systemctl  set-default  NAME.target

运行原理其实就是创建和删除软链接文件

blob.png

    切换值紧急救援模式:systemctl rescue(级别1,会执行/etc/rc.d/init)

    切换值emergency模式:systemctl emergency(最简洁的模式,)

其他常用命令:

    关机:systemctl halt, systemctl poweroff

    重启:systemctl reboot

    挂载:systemctl suspend

    快照:systemctl hibernate

    快照并挂起:systemctl hybrid-sleep

service  unit file:

    

    相关布尔值,1 、yes 、on 、true  都是开启,0 、no 、off、false 

     文件通常有三部分组成: 

     [Unit] :定义与unit类型无关的通用选项;用于提高unit的描述信息,unit行为及依赖关系等;

     [Service] :定义与特定类型相关的专业选项;此处为service

     [Install] :定义有“systemctl enable”以及“systemctl disable ”命令在实现服务启动和禁用时用到的一些选项

blob.png

unit段的常用选项:

          Description:描述信息,意义性描述

          After:定义unit的启动次序;表示当前unit应该晚于那些unit启动;其功能与before相反

          Wants:依赖到的其他units;(弱依赖),被依赖的units无法激活时,当前unit可以激活

          Requies:依赖到的其他units;(强依赖),被依赖的units无法激活时,当前unit即无法激活

          Conflicts:定义units间的冲突关系;

service段的常用选项:

type:用于定义影响ExecStart及相关参数的功能的unit进程启动类型

    类型:

        simple:由ExecStart所指明的程序启动起来的服务就是主进程(默认值,这个daemon 主要由ExecStart 接的指令串来启动

        ,启动后常驻于内存中)

        forking:由ExecStart所指明的程序启动起来的服务生成的一个子进程将成为主进程,启动完成后,父进程会退出

        oneshot:与simple 类似,不过这个程序在工作完毕后就结束了,不会常驻在内存中

        dbus:与simple 类似,但这个daemon 必须要在取得一个D-Bus的名称后,才会继续运作. 因此通常也要同时设定BusNname= 才行

        notify:类似于simple,在启动完成后会发送一个通知消息。还需要配合

        idle:与simple 类似,要执行这个daemon 必须要所有的工作都顺利执行完毕后才会执行。这类的daemon 通常是开机到最后才执行即可的服务

    EnvironmentFile:定义环境配置文件(此文件会在Exer之前读取,并为Exec提供变量)

    ExecStart:指明启动unit要运行命令或脚本;ExecStartPre(预运行),ExecStartPost(后运行)

    ExecStop:指明停止unit要运行的命令或脚本

    Restart:当设定Restart=1  时,则当次daemon 服务意外终止后,会再次自动启动此服务

      

Install段的常用选项

          Alias:

          RequiredBy:被哪些units所依赖(强依赖)

          WantdBy:被哪些units所依赖(若依赖)

        Also:安装本服务的时候还要安装别的相关服务

注意:对于新创建的unit文件或修改了的unit文件,要通知systemd重载此配置文件

          #systemctl daemon-reload

          

CentOS 7引导顺序 

1.UEFi 或BIOS 初始化,运行POST开机自检

2.选择启动设备

3.引导装载程序,cetnos 7 是gurb2

4.加载装载程序的配置文件:/etc/grub.d/ /etc/default/grub /boot/grub2/grub.cfg

5.加载initramfs驱动模块

6.加载内核模块

7.内核初始化,centos 7使用systemd代替了init

8.执行initrd.target所有单元,包括挂载/etc/fatab

9.从initramfs根文件系统切换到磁盘根目录

10systemd执行默认target配置,配置文件/etc/systemd/default.target /etc/systemd/system/

11.systemd执行sysinit.target初始化系统以及basic.target准操作系统

12.systemd启动multi-user.target下的本机与服务器服务

13.systemd执行multi-user.target下/etc/rc.d/rc.local

14.systemd执行multi-user.target下的getty.target及登入服务

15.systemd执行graphical需要的服务

设置内核参数

设置内核参数,只影响当次启动

启动时,在linux16 行后添加

    systemd.unit=desired.target

    systemd.unit=emergency.target

    systemd.unit=recure.target

recure.target比emergency.targe支持更多的功能,例如日志等

启动排错

文件系统损坏

先尝试自动修复,失败则进入emergency shell,提示用户修复

在 在/etc/fstab 不存在对应的设备和UUID等一段时间,如不可用,进入emergency shell

在/etc/fstab 不存在对应挂载点systemd尝试创建挂载点,否则提示进入emergency shell.

在/etc/fstab 不正确的挂载选项,提示进入emergency shell

破解root口令

1.启动时任意键暂停启动

2.按e键进入编辑模式

blob.png

3.将光标移动linux16 开始的行,添加内核参数rd.break

blob.png

4.按ctrl+x启动

blob.png

5.mount –o remount,rw /sysroot 因为是只读挂载,所要重新挂载,好切换到root环境

blob.png

6.chroot /sysroot切换到root环境

blob.png

7.修改密码

8.touch /.autorelabel(必须有此步骤)

blob.png

9.exit退出,重启,登入成功

blob.png

修复grub2

GRUB “the Grand Unified Bootloader” 引导提示时可以使用命令行界面,可从文件系统引导

主要配置文件:/boot/grub2/grub.cfg

修复配置文件:

    grub2-mkconfig> /boot/grub2/grub.cfg

修复grub(和centos 6的修复一样,就是命令换成了grub2-install,这里就不详细说了,参照前次博客)

grub2-install /dev/sda BIOS环境

grub2-install UEFI环境

原创文章,作者:qiuwei,如若转载,请注明出处:http://www.178linux.com/48257

(0)
上一篇 2016-09-22 09:17
下一篇 2016-09-22 10:04

相关推荐

  • 马哥教育网络第21期-第十四周课程练习

    系统的INPUT和OUTPUT默认策略为DROP; iptables -P INPUT DROP iptables -P OUTPUT DROP 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问; web服务器仅允许…

    Linux干货 2016-12-26
  • Linux磁盘和文件系统管理

      Linux磁盘和文件系统管理.pdf Part.I 磁盘管理 1.cfdisk   #图形化的很简单. 不知道你们用什么 反正我喜欢这个 ^_^ cfdisk – display or manipulate disk partition table 必要参数的具体说明如下: -a用箭头表示选取,而不是以反白表示 …

    Linux干货 2016-04-05
  • RAID有点意思

        独立硬盘冗余阵列(RAID, Redundant Array of Independent Disks),旧称廉价磁盘冗余阵列(Redundant Array of Inexpensive Disks),简称磁盘阵列。其基本思想就是把多个相对…

    Linux干货 2017-06-19
  • FHS文件系统各目录功能

    前言:     文件系统是一种存储和组织计算机数据的方法,它使得对其访问和查找变得容易。linux的哲学是一切皆文件,linux系统中的一切包括设备文件,我们都能在linux的倒置树状文件系统中找到相对应的文件。所以清楚的明白根目录下的每个子目录包含什么样的文件是很有必要的。我们将以Filesystem Hierarchy Standar…

    Linux干货 2016-10-17
  • Nginx 负载均衡多个nmmp主机

    设计拓扑图 一、Memcache简介 cache(缓存系统) 高性能分布式缓存服务器,缓存所有的“可流式化”数据:livejournal旗下Danga Interacive公司 程序=指令+数据 指令:程序 数据:IO操作 文件系统: 特征:协议简单  基于libevent的事件处理  内置内存存储方式  memcached 不…

    2016-06-14
  • keepalived实现前端负载均衡器的高可用

    概述:     在之前的内容中,我们了解了当一个网站并发量大时,可以利用前端负载均衡器将用户请求调度到后端的多个real server上,实现分散服务压力,横向扩展的方式,形成LB集群,但是试想一下,作为前端负载均衡器:     如果是LVS,万一作为前端调度器的Director…

    Linux干货 2016-11-01