Linux系统管理之十四---服务

一、inittab文件详解

(一)inittab文件详解:

#   0 - halt (Do NOT set initdefault to this)        //停止、关闭linux,停止所有服务
#   1 - Single user mode                            //单用户模式
#   2 - Multiuser, without NFS                      //多用户方式,不能访问NFS
#   3 - Full multiuser mode                         //多用户方式,启动计算机上的网络监控
#   4 - unused                                       //保留没做定义
#   5 - X11                                         //图形登录
#   6 - reboot (Do NOT set initdefault to this)     //重新启动

id:3:initdefault:                  //设定系统默认的运行级别,此处就是3.

redhat5以下有下面的内容,redhat6就没有下面的内容了,但实现的功能都一样。
# System initialization.
si::sysinit:/etc/rc.d/rc.sysinit  //通过sysinit进行系统的初始化,这个是一定会运行的。

l0:0:wait:/etc/rc.d/rc 0                //对应上面定义的各个级别。此处就是当选择0级别时运行的脚本和程序。 运行的脚本存于/etc/rc.d/rc0.d目录下。  
l1:1:wait:/etc/rc.d/rc 1                //1级别时的运行脚本。将启动/etc/rc.d/rc1.d目录下所有s开头的脚本,停止k开头的所有脚本。以下级别类推。
l2:2:wait:/etc/rc.d/rc 2                
l3:3:wait:/etc/rc.d/rc 3                
l4:4:wait:/etc/rc.d/rc 4
l5:5:wait:/etc/rc.d/rc 5              
l6:6:wait:/etc/rc.d/rc 6

# Trap CTRL-ALT-DELETE
ca::ctrlaltdel:/sbin/shutdown -t3 -r now    //定义重启键。如果注释掉,那么按ctrlaltdel三个键就不会重启了。

1:2345:respawn:/sbin/mingetty tty1
    2:2345:respawn:/sbin/mingetty tty2
    3:2345:respawn:/sbin/mingetty tty3
    4:2345:respawn:/sbin/mingetty tty4
    5:2345:respawn:/sbin/mingetty tty5
    6:2345:respawn:/sbin/mingetty tty6
    这指明了系统默认要启动几个虚拟控制台,可以按Ctrl + Alt + F1~F6切换。
    第二列的2345表明它们会运行在这四个级别上
    而respawn则表明该命令会一直被调用。最常见的例子就是在shell环境下,我们输入exit退出环境,但随后又会出现login提示符,等待新的用户登录。
    这里设定了六个虚拟控制台,如果不需要那么多的话,可以把多余的注释掉。

(二)
/etc/inittab的任务:

1、设定默认运行级别
2、运行系统初始化脚本  /etc/rc.d/rc.sysint
3、运行指定运行级别对应的目录下的脚本
4、设定ctrl+alt+del组合键的操作
5、定义UPS电源在电源故,恢复时执行的操作
6、启动虚拟终端
7、启动图开终端。

二、/etc/rc.d/rc.sysinit脚本完成的任务:

1、激活UDEV 和SELINUX
2、根据/etc/sysctl.conf文件来设定内核参数
3、设定时钟
4、装载键盘映射
5、启用交换分区
6、设置主机名
7、根文件系统检测,并以读写文式重新挂载
8、激活RAID和LVM设备
9、启用磁盘配额
10、检查并挂载其他文件系统
11、清理过期的锁和PID文件

三、对应级别的脚本
先执行 /etc/rc.d/rc.sysinit脚本
再执行指定的级别的脚本

/etc/rc.d/rc#.d       //  在/etc/rc.d/目录下有相应执行级别的目录,即选择几号,就执行相应目录下的脚本和服务。

k*  :以K开头的脚本是停止执行的。即  stop
           s*   以S开头的脚本是启动执行的,即start

四、服务类脚本的说明

1、redhat脚本是采用的SysV风格
2、/etc/rc.d/init.d 和  /etc/init.d    // 服务类脚本都在这两个目录下,其实这两个目录是一样的,后者其是前一个目录的链接。

3、服务类脚本格式详解:
例:
#chkconfig: 2345 25 10

//第一组设定默认启动的级别,这里表明这个服务脚本在级别2345级时都启动。   第二组  ss,即25是启动的优先次序   第三组:kk,即10关闭的优先次序。 ss+kk两组数字加起来大致等于99

#description: Startup/shutdown script for the Common UNIX \
#                Printing System (CUPS).
//描述脚本的简单功能,用  \,进行续行。

start |stop |restart|status   // 每个服务脚本起码拥有这四个参数
  reload|configtest             //可选参数

五、chkconfig命令的使用:

1、先写好脚本,然后放到/etc/rc.d/init.d下面,然后执行chkconfig命令可以添加到服务脚本中,即可以定义这个脚本开机是运行,还是不运行,运行在哪个级别。也可以把已加入到服务脚本的脚本删除。
chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息。谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接。

2、使用语法:
chkconfig [--add][--del][--list][系统服务] 或 chkconfig [--level <等级代号>][系统服务][on/off/reset]

chkconfig在没有参数运行时,显示用法。如果加上服务名,那么就检查这个服务是否在当前运行级启动。如果是,返回true,否则返回false。如果在服务名后面指定了on,off或者reset,那么chkconfi 会改变指定服务的启动信息。on和off分别指服务被启动和停止,reset指重置服务的启动信息,无论有问题的初始化脚本指定了什么。on和off开关,系统默认只对运行级3,4,5有效,但是reset可以对所有运行级有效。

参数用法:
   --add  增加所指定的系统服务,让chkconfig指令得以管理它,并同时在系统启动的叙述文件内增加相关数据。
   --del  删除所指定的系统服务,不再由chkconfig指令管理,并同时在系统启动的叙述文件内删除相关数据。
   --level<等级代号>  指定读系统服务要在哪一个执行等级中开启或关毕。
      等级0表示:表示关机
      等级1表示:单用户模式
      等级2表示:无网络连接的多用户命令行模式
      等级3表示:有网络连接的多用户命令行模式
      等级4表示:不可用
      等级5表示:带图形界面的多用户模式
      等级6表示:重新启动
      需要说明的是,level选项可以指定要查看的运行级而不一定是当前运行级。对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。

chkconfig --list [name]:显示所有运行级系统服务的运行状态信息(on或off)。如果指定了name,那么只显示指定的服务在不同运行级的状态。
    chkconfig --add name:增加一项新的服务。chkconfig确保每个运行级有一项启动(S)或者杀死(K)入口。如有缺少,则会从缺省的init脚本自动建立。
    chkconfig --del name:删除服务,并把相关符号连接从/etc/rc[0-6].d删除。
    chkconfig [--level levels] name:设置某一服务在指定的运行级是被启动,停止还是重置。

运行级文件:
每个被chkconfig管理的服务需要在对应的init.d下的脚本加上两行或者更多行的注释。第一行告诉chkconfig缺省启动的运行级以及启动和停止的优先级。如果某服务缺省不在任何运行级启动,那么使用 - 代替运行级。第二行对服务进行描述,可以用\ 跨行注释。
例如,random.init包含三行:
# chkconfig: 2345 20 80
# description: Saves and restores system entropy pool for \
# higher quality random number generation.

使用范例:
chkconfig --list        #列出所有的系统服务
chkconfig --add httpd        #增加httpd服务
chkconfig --del httpd        #删除httpd服务
chkconfig --level httpd 2345 on        #设置httpd在运行级别为2、3、4、5的情况下都是on(开启)的状态
chkconfig --list        #列出系统所有的服务启动情况
chkconfig --list mysqld        #列出mysqld服务设置情况
chkconfig --level 35 mysqld on        #设定mysqld在等级3和5为开机运行服务,--level 35表示操作只在等级3和5执行,on表示启动,off表示关闭
chkconfig mysqld on        #设定mysqld在各等级为on,“各等级”包括2、3、4、5等级

例:
如何增加一个服务:
1.服务脚本必须存放在/etc/init.d/目录下;
2.chkconfig --add servicename   //把脚本添加到服务脚本中,不指定运行级别就默认是2345
    在chkconfig工具服务列表中增加此服务,此时服务会被在/etc/rc.d/rc#.d中赋予K/S入口了;
3.chkconfig --level 35 mysqld on
    修改服务的默认启动等级。

注意:在/etc/rc.d/rc#.d/等目录中最后都有个s99local脚本,其实是链接到/etc/rc.d/rc.local中的,即是最后运行的脚本。 可以把开机想运行的命令写到这个脚本中即可以开机执行了。

六、守护进程类型:

独立守护进程
          
   瞬时守护进程 : xinetd:超级守护进程,负责瞬时守护进程的管理。不需要关联至运行级别。默认是没有安装的。

时间: 2024-10-14 11:26:35

Linux系统管理之十四---服务的相关文章

linux杂谈(十四):ftp的企业应用级的配置(一)

1.ftp简介 (1)生活中的ftp 在互联网中我们需要传输数据,尤其是要传输大型数据.有一个服务是要着重去介绍的:ftp.其实我们以前很早就接触它了.只是大家可能不怎么关注,迅雷的基本模型就是ftp,不过是要高级的多. 事实上ftp应该是一种传输协议,之前它采用的是明文传输,如果在复杂的网络环境这样使用的话是非常危险的.为了更安全的使用这个协议,现在我们要采取更安全的软件vsftpd来提供服务. (2)ftp的功能介绍 1.它有着不同等级的用户身份:服务器本地用户:访客:匿名用户: 2.命令记

攻城狮在路上(叁)Linux(二十四)--- linux设置开机挂载及镜像文件挂载

虽然可以手动进行文件系统的挂载,但是每次都手动挂载就会很麻烦,开机挂载的目的就是实现文件系统的自动挂载. 一.开机挂载:/etc/fstab及/etc/mtab 主要是通过修改/etc/fstab文件的配置来实现. fstab是开机时的设置,实际文件系统的挂载是记录到/etc/mtab和/proc/mounts这两个文件中. 1.系统挂载的限制: A.根目录/必须挂载,而且一定是最先挂载的,要先于其他mount point. B.其他挂载点必须为已新建的目录,可以任意指定. C.所有挂载点在同一

linux基础-第十四单元 Linux网络原理及基础设置

第十四单元 Linux网络原理及基础设置 三种网卡模式图 使用ifconfig命令来维护网络 ifconfig命令的功能 ifconfig命令的用法举例 使用ifup和ifdown命令启动和停止网卡 ifup命令的功能 ifdown命令的功能 ifup命令的用法举例 ifdown命令的用法举例 网络配置文件 网卡对应的网络配置文件 什么是网络配置 ip命令 ping命令 setup命令 课后作业 [本节内容]1. 使用ifconfig命令来维护网络(详见linux系统管理P422)1) 掌握if

Linux系统管理初步(四)Linux系统的防火墙-netfilter 编辑中

一.Linux的防火墙 防火墙是日常应用中一个重要的维护内容,从防火墙开始我们才真正接触生产环境,网络安全越来越受重视,学好这部分内容是学好运维的重要一步. 一般情况下,桌面级环境中很少有人关注过防火墙,甚至杀毒软件都不装,对防火墙的操作当然不熟悉.真实生产环境中不可能不开防火墙. linux的防火墙在centos6(含)前是netfilter,centos7开始使用新的firewalld,一般的我们从netfilter学起,firewalld是兼容netfilter的规则的. 二.netfil

Linux时间子系统(十四) tick broadcast framework

一.前言 在内核中,有cpuidle framework可以控制cpu的节电:当没有进程调度到该cpu上执行的时候,swapper进程粉墨登场,将该cpu会被推入到idle状态.当然CPU的idle状态有深有浅,当CPU睡的比较深入的时候,有可能会关闭本地的timer硬件.这样就会引入一个很有意思的问题:local timer将无法唤醒CPU,该cpu上的所有的software timer将无法唤醒cpu.tick broadcast framework就是用来解决这个问题的. 本文中的代码来自

Linux系统管理之十五---shell

一.shell基础1.shell的基本概念shell就是系统跟计算机硬件交互时使用的中间介质,它只是系统的一个工具.用户界面shell(还有其他用户界面如kde等图形界面)-->内核-->硬件. 2.shell的种类/bin/sh/bin/bash  默认shell/bin/ksh   兼容bash/bin/tcsh  c shell/bin/csh   已被tcsh替代,c shell可以在/etc/shells文件中查看有哪些shell种类, 以下我们要学的都是bash这个shell的知识

我和linux的第二十四天

今天简单看了shell script,运用简单的程序脚本来管理linux系统.看了些,最后决定先简单了解下,以后用到再回头仔细研读. linux中的shell script shell script是利用shell的功能所写的一个"程序"(program),这个程序是使用纯文本文件,将一些shell的语法与命令(含外部命令)写在里面,搭配正则表达式,管道命令与数据流重定向等功能,以达到我们所想要的处理目的. shell script在linux中的作用: 自动化管理的重要依据: 追踪与

伙伴系统之伙伴系统概述--Linux内存管理(十四)

日期 内核版本 架构 作者 GitHub CSDN 2016-09-02 Linux-4.7 X86 & arm gatieme LinuxDeviceDrivers Linux内存管理 1 前景回顾 1.1 Linux内存管理的层次结构 Linux把物理内存划分为三个层次来管理 层次 描述 存储节点(Node) CPU被划分为多个节点(node), 内存则被分簇, 每个CPU对应一个本地物理内存, 即一个CPU-node对应一个内存簇bank,即每个内存簇被认为是一个节点 管理区(Zone)

linux学习笔记十四:安装SAMBA(Server Message Block)

NFS:仅用于Linux之间 CIFS:仅用于Windows之间 SAMBA:可用于Linux与Windows之间,基于NetBIOS协议(用于LAN内部,不能跨路由),没有IP地址的概念,根据 NetBIOSName来区分主机. 两个服务: nmbd:UDP的137.138,管理工作组.NetBios name等. smbd:TCP的139,管理分享的目录.文件.打印机等. 两种模式:peer/peer(workgroup,对等模式). domain(域,主控模式) 1.安装samba.sam