N26-第十周

1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情)

    看到同学的图不错拿来用用 ~ ~

    N26-第十周

2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;
  (1) 为硬盘新建两个主分区;并为其安装grub;
  (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
  (3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;
  (4) 为grub提供配置文件;

  (5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;

    

--创建两个分区--
[root@localhost ~]# fdisk -l /dev/sdb

Disk /dev/sdb: 21.5 GB, 21474836480 bytes
255 heads, 63 sectors/track, 2610 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0xa59bf598

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1               1          65      522081   83  Linux
/dev/sdb2              66        1371    10490445   83  Linux
--格式化分区--
[root@localhost ~]# mkfs -t ext4 /dev/sdb1
[root@localhost ~]# mkfs -t ext4 /dev/sdb2
--创建挂载目录并挂载-- [root@localhost ~]# mkdir  /mnt/{boot,sysroot}
[root@localhost ~]# mount /dev/sdb1 /mnt/boot/
[root@localhost ~]# mount /dev/sdb2 /mnt/sysroot/
--复制内核文件和ramdisk文件--
[root@localhost ~]# cp /boot/vmlinuz-2.6.32-358.el6.x86_64  /mnt/boot/vmlinux_new
[root@localhost ~]# cp /boot/initramfs-2.6.32-358.el6.x86_64.img  /mnt/boot/initramfs_new.img
--创建根下需要的目录--
[root@localhost ~]# mkdir /mnt/sysroot/{bin,dev,etc,home,lib,lib64,media,mnt,opt,proc,root,sbin,selinux,srv,sys,tmp,usr,var}

--复制bash、cat、ls程序文件和库文件--

[root@localhost ~]# cp `which --skip-alias bash` /mnt/sysroot/$(which --skip-alias bash)[root@localhost ~]# cp `which --skip-alias cat` /mnt/sysroot/$(which --skip-alias cat)[root@localhost ~]# cp `which --skip-alias ls` /mnt/sysroot/$(which --skip-alias ls)

[root@localhost ~]# cp -u $(ldd  `which --skip-alias ls` | grep -o "/.*\.[0-9]") /mnt/sysroot/lib64/[root@localhost ~]# cp -u $(ldd  `which --skip-alias cat` | grep -o "/.*\.[0-9]") /mnt/sysroot/lib64/

[root@localhost ~]# cp -u $(ldd  `which --skip-alias bash` | grep -o "/.*\.[0-9]") /mnt/sysroot/lib64/

--创建grub文件夹并创建grub.conf文件--

[root@localhost ~]# mkdir /mnt/boot/grub

[root@localhost ~]# vim /mnt/boot/grub/grub.conf

default=0timeout=5title little system        root (hd0,0)        kernel /vmlinuz_new root=/dev/sdb2 init=/bin/bash        initrd /initramfs_new.img

--安装grub到第二块硬盘--[root@localhost ~]# grub-install --root-directory=/mnt/ /dev/sdb



重启进入bios调整启动硬盘

N26-第十周

N26-第十周

N26-第十周

3、制作一个kickstart文件以及一个引导镜像。描述其过程。

        1、centos系统安装基于anaconda程序进行的,在系统安装完毕后会自动生成一个anaconda-ks.cfg的文件,该文件可直接或编辑后作为kickstart的脚本文件。

        2、安装system-config-kickstart命令(该命令需要运行在图形模式下)并使用该命令生成或修改kickstart的脚本文件

#命令行段
filewall --disabled #禁用防火墙
install  #执行新安装
cdrom  #使用光盘进行安装
lang en_US.UTF-8  #设置安装语言
keyboard us  #设置键盘格式
network --onboot no --device eth0 --bootproto dhcp --noipv6  #设置网络
rootpw  --iscrypted $6$tRmCwYXf5Nt/frJK$6lnrag1bLng6xqhvvL.BVdK/jFJo4l4q6J3mcbchVmWCcQH6T45O8yd406pb3/1Ins2YiDAePvM/YmVZ41uFR. #设置root密码
authconfig --enableshadow --passalgo=sha512 #认证方式
selinux --disabled #关闭selinux
timezone --utc Asia/Shanghai  #设置时区
bootloader --location=mbr --driveorder=sda,sdb --append="crashkernel=auto rhgb quiet"  #bootloader设置 
repo --name="CentOS"  --baseurl=cdrom:sr0 --cost=100 #设置软件仓库
clearpart --all//删除所有现在分区 
part /boot --fstype=ext4 --size=200//分区挂载
part / --fstype=ext4 --size=40960
part swap --size=4096
#脚本段
%pre//安装前脚本
echo "start install"
%end
%post # 安装后脚本
echo "install end"
#程序包段
%packages
@chinese-support  #中文支持
@development  #开发工具
@graphical-desktop-clients  #图形化工具
@remote-desktop-clients  #远程桌面客户端
%end

制作centos6.X 引导镜像文件

--创建文件夹存放启动文件--
[root@localhost /]# mkdir /myboot
--复制光盘中的文件--
[root@localhost /]# cp -r /media/isolinux/* /myboot
--复制制作好的ks文件--
[root@localhost /]# cp /root/ks.cfg /myboot/ks.cfg
--修改solinux.cfg文件--
[root@localhost /]#echo "append initrd=initrd.img ks=cdrom:/ks.cfg" > /myboot/solinux.cfg
--生成iso文件--
[root@localhost /]#  mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V "CentOS 6 x86_64 boot" -c boot.cat -b isolinux.bin -o  /root/boot.iso   /myboot

4、写一个脚本
  (1) 能接受四个参数:start, stop, restart, status
   start: 输出“starting 脚本名 finished.”
   …

  (2) 其它任意参数,均报错退出;

#!/bin/bash
#
#
#
case $1 in
        start)
        echo "starting $0 finished"
        ;;
        stop)
        echo "stoping $0 finished"
        ;;
        restart)
        echo "restartting $0 finished"
        ;;
        status)
        echo "status $0 finished"
        ;;
        *)
        echo "error"
        ;;
esac

5、写一个脚本,判断给定的用户是否登录了当前系统;
  (1) 如果登录了,则显示用户登录,脚本终止;

  (2) 每3秒钟,查看一次用户是否登录;

    

#!/bin/bash
#
#
#
USER=`who |cut -d " " -f1 `
[ $# -ne 1 ] && echo "use $0 username " && exit 1
 if ! id $1 &>/dev/null ;then
        echo "$1 is not a username"
        exit 2
fi
while true; do
        if echo $USER| grep $1  &>/dev/null ;then
                echo "$1 is loggin"     
                break
        fi
        sleep 3
done

6、写一个脚本,显示用户选定要查看的信息;
   cpu) display cpu info
   mem) display memory info
   disk) display disk info

   quit) quit

   非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;

#!/bin/bash
#
#
#
cat <<EOF
   cpu) display cpu info
   mem) display memory info
   disk) display disk info
   quit) quit
EOF
read -p "input your choice " option

while true;do
        case $option in
                cpu)
                cat /proc/cpuinfo
                break
                ;;
                mem)
                cat /proc/meminfo
                break
                ;;
                disk)
                fdisk -l
                break
                ;;
                quit)
                break
                ;;
                *)
                echo "syntax error;use $0 cpu|mem|disk|quit"
                read -p "input your choice again " option
                ;;
        esac
done

7、写一个脚本
  (1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;
  (2) 提示用户输入一个用户名或输入“quit”退出;
    当输入的是用户名,则调用函数显示用户信息;

    当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit: 

#!/bin/bash
#
#
#

USERINFO() {

        grep "^$1" /etc/passwd | awk -F: '{print $3i" "$7}'

}

read -p "input a username " USERNAME

while true ;do
        case $USERNAME in
            quit)
                break
        ;;
                *)
                if  id $USERNAME &>/dev/null ;then
                        USERINFO $USERNAME
                        read -p "input  another user name or quit " USERNAME
                else
                        echo "$USERNAME is not a username "
                        read -p "please input a username again or quit " USERNAME
                fi
        ;;
        esac
done

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

(0)
胡安慧胡安慧
上一篇 2017-03-25 22:40
下一篇 2017-03-26 13:03

相关推荐

  • N25-第一周博客作业

    计算机的组成及其功能 Linux的发行版介绍 Linux的哲学思想 Linux命令格式及一些基础命令 在Linux系统上获取命令的帮助信息 Linux发行版的基础目录 计算机的组成及其功能 简单来说,计算机系统是由 硬件系统(hardware system)和 软件系统(software system)两部分组成。 硬件的基本组成: 运算器、存储器、控制器、…

    Linux干货 2016-12-02
  • 计算机组成及Linux初识

    拼一载春秋,搏一生无悔 1. 计算机简介 2. Linux发行版简介 3. Linux哲学思想简介 4. Linux系统上获取命令帮助 5. Linux「12」个基础命令简介 6. Linux发行版基础目录及功能简介 1.计算机简介 电子计算机(英语:computer),亦称电脑,是一种利用「电子学…

    Linux干货 2016-10-27
  • centos 7.3二进制安装mariadb10.2.8

    1 rpm -qa mariadb* 2 getent passwd mysql useradd -d /app/mysqldb -r -m -s /sbin/nologin mysql 3 tar xvf mariadb-10.2.8-linux-x86_64.tar.gz -C /usr/local/cd /usr/local/ln -s mariadb…

    Linux干货 2017-10-16
  • proxy_pass转发路径

    一、引言 在nginx中配置proxy_pass时,proxy_pass后面的路径最后面加“/”和不加“/”会有所区别。加“/”时,nginx不会代理location部分,不加“/”时,nginx会同时代理location部分。下面通过实验来证明。 二、实验 实验环境简要说明:     node1为httpd服务器(1…

    Linux干货 2017-01-12
  • 用户组和权限管理

    一、3A认证     Authentication:认证     Autherization:授权     Accoutiong|Audition:审计 二、用户user      linu…

    Linux干货 2016-08-04
  • 部署LAMP之WordPress, PMA(https), Discuz

    一、环境介绍     系统:CentOS 6.7     软件:httpd-2.2, mysql-5.3, wordpress-4.3, pma4.0     网络:       …

    Linux干货 2016-03-24

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-30 14:23

    可以看出脚本运用的已经比较熟练了,继续加油。