系统自动化安装、selinux

系统自动化安装

系统启动流程:bootloader–>kernel(initramfs)–>rootfs–>anaconda–>/sbin/init

anaconda: 系统安装程序
    tui: 基于图形库curses的文本配置窗口
    gui:图形窗口

安装程序启动过程
 MBR:isolinux/boot.cat
 stage2: isolinux/isolinux.bin
    配置文件:isolinux/isolinux.cfg
      每个对应的菜单选项:
        加载内核:isolinuz/vmlinuz
        向内核传递参数:append initrd=initrd.img…
 装载根文件系统,并启动anaconda
        默认启动GUI接口
        若是显式指定使用TUI接口:向内核传递text参数即可
        (1)按tab键,在后面增加text
        (2)按ESC键:boot: linux text  

启动安装过程一般应位于引导设备;后续的anaconda及其安装用到的程序包等可来自下面几种方式:本地光盘、本地硬盘、U盘或网络(ftp server、http server、nfs server)
如果想手动指定安装源:按ESC键 ;boot: linux askmethod 或 boot: linux method

Anaconda安装系统分成三个阶段:
安装前配置阶段
    安装过程使用的语言
    键盘类型
    安装目标存储设备
        Basic Storage:本地磁盘
        特殊设备:iSCSI
    设定主机名
    配置网络接口
    时区
    管理员密码
    设定分区方式及MBR的安装位置
    创建一个普通用户
    选定要安装的程序包
安装阶段
    在目标磁盘创建分区,执行格式化操作等
    将选定的程序包安装至目标位置
    安装bootloader和initramfs
首次启动
    iptables
    selinux
    core dump

anaconda的配置方式:
    (1) 交互式配置方式
    (2) 通过读取事先给定的配置文件自动完成配置;按特定语法给出的配置选项;kickstart文件

安装boot引导选项:
    boot:
     text: 文本安装方式
     method或askmethod: 手动指定使用的安装方法
     与网络相关的引导选项:
          ip=IPADDR
          netmask=MASK
          gateway=GW
          dns=DNS_SERVER_IP
          ifname=NAME:MAC_ADDR
     与远程访问功能相关的引导选项:
          vnc
          vncpassword='PASSWORD'
      启动紧急救援模式
            rescue
      装载额外驱动
            dd
www.redhat.com/docs,《indtallation guide》 获取安装说明信息

指明kickstart文件的位置:
ks=
    DVD drive: ks=cdrom:/PATH/TO/KICKSTART_FILE
    Hard drive: ks=hd:device:/directory/KICKSTART_FILE
    HTTP server: ks=http://host:port/path/to/KICKSTART_FILE
    FTP server: ks=ftp://host:port/path/to/KICKSTART_FILE
    HTTPS server: ks=https://host:port/path/to/KICKSTART_FILE
    NFS server:ks=nfs:host:/path/to/KICKSTART_FILE

kickstart文件的格式
命令段:指明各种安装前配置,如键盘类型等;
程序包段:指明要安装的程序包组或程序包,不安装的程序包等;
    %packages  程序包段起始位置
    @group_name  安装一个包组
    package  安装某个程序包
    -package  D不安装某个程序包(当指定为不安装的程序包,若被其他程序依赖也将会被安装)
    %end  程序包段结束位置
脚本段:
    %pre: 安装前脚本
        运行环境:运行于安装介质上的微型Linux环境
    %post: 安装后脚本
        运行环境:安装完成的系统;

命令段中的命令:
    authconfig: 认证方式配置
        authconfig–useshadow–passalgo=sha512
    bootloader:bootloader的安装位置及相关配置
        bootloader –location=mbr –driveorder=sda#
            append="crashkernel=auto rhgb quiet"
    keyboard: 设定键盘类型
    lang: 语言类型
        lang zh_CN.UTF8
    part: 创建分区
        part /boot –fstype=ext4 –size=500
        part pv.008002 –size=51200
    rootpw: 指明root的密码
        openssl passwd -1 -salt `openssl rand -hex 4` 使用md5加密方式生成加密密码
        rootpw –iscrypted
    timezone: 时区
        timezone Asia/Shanghai

补充:分区相关的其他指令
    clearpart:清除分区
        clear –none –diver=sda:清空磁盘分区
    volgroup:创建卷组
        volgroup myvg –presize=4096 pv.008002
    logvol:创建逻辑卷
        logvol /home –fstype –name=lv_home –vgname=myvg –size=5120

可选命令
    install OR upgrade:安装或升级
    text: 文本安装界面,默认为图形安装界面
    network:配置网络接口
        network –onboot yes –device eth0 –bootproto –noipv6
    firewall:防火墙
        firewall –disable
    selinux:SElinux
        selinux –disable
    halt|poweroff|reboot:安装完成之后的行为
    repo:指明安装时使用的repository
    user:安装完成后为系统创建新用户
    url: 指明安装源
        url –url="http://mirrors.aliyun.com/centos/6.8/os/x86_64/"
    key –skip:跳过安装号码,适用于rhel版本

系统安装完成之后
    禁用防火墙
        CentOS 6:
            service iptables stop
            chkconfig iptables off
        CentOS 7:
            systemctl stop iptables
    禁用SElinux
        永久有效
            修改/etc/sysconfig/selinux或/etc/selinux/config
            selinux=permissive或disabled
         立即生效
            setenforce 0
        查看状态
            getenforce

创建kickstart文件的方式:
(1) 直接手动编辑;
    依据某模板修改
(2) 可使用创建工具:system-config-kickstart
    依据某模板修改并生成新配置;
        http服务器:mirrors.aliyun.com
        http目录:/centos/6.8/os/x86_64/
   检查ks文件的语法错误:ksvalidator

创建引导光盘:
cp /media/cdrom/isolinux/ /tmp/myiso/
vi /tmp/myiso/isolinux/isolinux.cfg
initrd=initrd.imgtext ks=cdrom:/myks.cfg
cp /root/myks.cfg /tmp/myiso/
cd /tmp
mkisofs -R -J -T -v –no-emul-boot –boot-load-size 4 –boot-info-table -V "CentOS 6.6 x86_64 boot" -b isolinux/isolinux.bin -c isolinux/boot.cat -o /root/boot.isomyiso/
 
创建U盘启动盘
    dd if=/dev/sr0 of=/dev/sdb
1 fdisk/dev/sdb–t -b 指定vfat
    mkfs.vfat/dev/sdb1
2 mount /dev/sdb1 /mnt/usb
    mkidr-p /mnt/usb/boot/grub
   cp/misc/cd/images/pxeboot/vmlinuz/misc/cd/images/pxeboot/initrd/mnt/usb/boot
3 vi /mnt/usb/boot/grub/grub.conf
    title wanglinux
    root (hd0,0)
    kernel /boot/vmlinuz
    initrd/boot/initrd.imgks=http://172.16.0.1/centos6.x86_64.cfg
4 #grub
    >root (hd1,0)
    >kernel /
    >setup ( hd1)
SELinux

SELinux介绍
SELinux: Secure Enhanced Linux,是美国国家安全局「NSA=The National Security Agency」和SCC(Secure Computing Corporation)开发的Linux的一个强制访问控制的安全模块。2000年以GNU GPL发布,Linux内核2.6版本后集成在内核中

DAC:Discretionary Access Control自由访问控制
MAC:Mandatory Access Control 强制访问控制
    DAC环境下进程是无束缚的
    MAC环境下策略的规则决定控制的严格程度
    MAC环境下进程可以被限制的
    策略被用来定义被限制的进程能够使用那些资源(文件和端口)
    默认情况下,没有被明确允许的行为将被拒绝

SELinux有四种工作类型:
 strict: centos5,每个进程都受到selinux的控制
 targeted: 用来保护常见的网络服务,仅有限进程受到selinux控制,只监控容易被入侵的进程,rhel4只保护13个服务,rhel5保护88个服务
 minimum:centos7,修改过的targeted,只对选择的网络服务
 mls:提供MLS(多级安全)机制的安全性
 minimum和mls稳定性不足,未加以应用

SELinux安全上下文
 传统Linux,一切皆文件,由用户,组,权限控制访问
 在SELinux中,一切皆对象,由存放在Inode的扩展属性域的安全元素所控制其访问。
 所有文件和端口资源和进程都具备安全标签:安全上下文”(security context)
 安全上下文有五个元素组成:
     user:role:type:sensitivity:category
     user_u:object_r:tmp_t:s0:c0
 实际上下文:存放在文件系统中,ls –Z;ps–Z
 期望(默认)上下文:存放在二进制的SELinux策略库(映射目录和期望安全上下文)中
        semanagefcontext–l

五个安全元素
  User:指示登录系统的用户类型,如root,user_u,system_u,多数本地进程都属于自由(unconfined)进程
  Role:定义文件,进程和用户的用途:文件:object_r,进程和用户:system_r
  Type:指定数据类型,规则中定义何种进程类型访问何种文件Target策略基于type实现,多服务共用:public_content_t
  Sensitivity:限制访问的需要,由组织定义的分层安全级别,如unclassified,secret,top,secret, 一个对象有且只有一个sensitivity,分0-15级,s0最低,
Target策略默认使用s0
  Category:对于特定组织划分不分层的分类,如FBI Secret,NSA secret, 一个对象可以有多个categroy,c0-c1023共1024个分类,Target 策略不使用cateaory

SELinux策略
 对象(object):所有可以读取的对象,包括文件、目录和进程,端口等,
 主体:进程称为主体(subject)
 SELinux中对所有的文件都赋予一个type的文件类型标签,对于所有的进程也赋予各自的一个domain的标签。Domain标签能够执行的操作由安全策略里定义。
 当一个subject试图访问一个object,Kernel中的策略执行服务器将检查AVC (访问矢量缓存Access Vector Cache), 在AVC中,subject和object的权限被缓存(cached),查找“应用+文件”的安全环境。然后根据查询结果允许或拒绝访问
 安全策略:定义主体读取对象的规则数据库,规则中记录了哪个类型的主体使用哪个方法读取哪一个对象是允许还是拒绝的,并且定义了哪种行为是充许或拒绝

配置SELinux:
    SELinux是否启用
    给文件重新打安全标签
    给端口设置安全标签
    设定某些操作的布尔型开关
    SELinux的日志管理
SELinux的状态:
    enforcing: 强制,每个受限的进程都必然受限
    permissive: 允许,每个受限的进程违规操作不会被禁止,但会被记录于审计日志
    disabled: 禁用

相关命令:
    getenforce: 获取selinux当前状态
    sestatus:查看selinux状态
    setenforce 0|1
        0: 设置为permissive
        1: 设置为enforcing
    注:setenforce 临时生效,若要永久生效修改器配置文件
配置文件:
/boot/grub/grub.conf  使用selinux=0禁用SELinux
/etc/sysconfig/selinux  /etc/selinux/config
    SELINUX={disabled|enforcing|permissive}
        enforcing或permissive切换至disabled需要重启,
        isabled切换至enforcing或permissive需要重启,
        enforcing与permissive之间切换不需要重启。

给文件重新打安全标签:
    chcon [OPTION]… [-u USER] [-r ROLE] [-t TYPE] FILE…
    chcon [OPTION]… –reference=RFILE FILE…  以模版文件设置安全标签
        -R:递归打标;
恢复目录或文件默认的安全上下文:
    restorecon [-R] /path/to/somewhere

默认安全上下文查询与修改,semanage来自policycoreutils-python包
    查看默认的安全上下文
        semanage fcontext -l
    添加安全上下文
        semanage fcontext -a -t httpd_sys_content_t ‘/testdir(/.*)?’
        restorecon -Rv /testdir
    删除安全上下文
        semanage fcontext -d –t httpd_sys_content_t ‘/testdir(/.*)?’
    查看端口标签
        semanage port –l
    添加端口
        semanage port -a -t port_label-p tcp|udp PORT
        semanage port -a -t http_port_t -p tcp 9527
    删除端口
        semanage port -d -t port_label-p tcp|udp PORT
        semanage port -d -t http_port_t -p tcp 9527
    修改
        semanage port -m -t port_label-p tcp|udp PORT
        semanage port -m -t http_port_t -p tcp 9527

SELinux布尔值
布尔型规则:
    getsebool
    setsebool
查看bool命令:
    getsebool [-a] [boolean]
    semanageboolean –l
    semanageboolean -l –C 查看修改过的布尔值
设置bool值命令:
    setsebool [-P] booleanvalue
    setsebool [-P] Boolean=value
        -P:永久有效,默认仅临时有效
SELinux日志管理 yum install setroublesshoot*(重启生效)
将错误的信息写入/var/log/message
   grep setroubleshoot/var/log/messages
   sealert-l UUID
查看安全事件日志说明
 sealert-a /var/log/audit/audit.log
扫描并分析日志
   [root@serverX ~]# yum -y install selinux-policy-devel
SELinux帮助
   [root@serverX ~]# mandb
   [root@serverX ~]# man -k _selinux

练习
 1、安装httpd服务,改变网站的默认主目录为/website,添加SELinux文件标签规则,设置http_sys_content_t到/website及目录下所有文件,使网站可访问
 2、修改网站端口为9527,增加SELinux端口标签,使网站可访问
 3、启用SELinux布尔值,使用户student的家目录可通过http访问

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

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

相关推荐

  • n28 第二周作业

    n28 第二周作业

    Linux干货 2017-12-09
  • 文件管理命令及通配符练习

    1.Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例 按增删改查的思路来 增: touch filename:这个命令本身不是用来新建文件的,它是用来修改文件的时间属性,不过默认情况时当filename不存在时,它会默认建立一个空文件 mkdir: 常用参数 -p:相当于递归创建目录 -v:显示出创建过程中的信息 cp : 常用参数 -r:…

    Linux干货 2016-11-06
  • 2016/10/14作业

    2016/10/14作业: ##操作类: 1. 设置自己的终端提示符,要求字符终端登录时: a> 需要带颜色  b> 需要显示当前执行到了第几条命令  c> 显示当前登录终端,主机名和当前时间 答:要在用户登录时终端提示符,需要更改当前系统的环境变量: /etc/bashrc文件 #[ "$PS1" …

    Linux干货 2016-10-19
  • tar,cpio,rpm,yum的使用详解(适合初学者)

    基于linux下的tar包管理和yum源配置 友情提示:对于这些实际操作的,还是需要进行手工的尝试,由于这几个对于包管理的是比较常用和实用的, 所以,一定要熟练使用。 1.tar tar是对于系统中文件,目录等进行打包,解包的工具。tar也可以对文件进行打包存放到别的目录下, 所以在很早的时候,一些老的工程师经常使用tar对文件进行备份。很大程度上,所谓的t…

    Linux干货 2016-08-21
  • vim的使用说明

    vim的使用说明 vim是一款功能丰富而强大的文本编辑器,vim是从 vi 发展出来的一个文本编辑器。其代码补全、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛的使用。 vim的使用非常方便,使用方法为:vim [options] [file ..] 1、vim可以对指定文件进行编辑,也可以直接启动vim编辑器进行编辑,对于打开指定文件编辑时可以加…

    Linux干货 2016-08-12
  • Hello word!

    初识linux

    2018-03-26