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

相关推荐

  • Linux小工具之cheat

    随着linux学习的深入,接触到的命令越来越多,此时,考验脑力的时候就到了,除非你是”脑王”,否则面对多如牛毛的linux命令,真的会崩溃!linux前辈们貌似也被同样的问题所困扰,所以,他们发明了cheat。cheat是在GNU通用公共许可证下,为Linux命令行用户发行的交互式备忘单应用程序。它提供显示Linux命令使用案例,包括该命令所有的选项和简短但…

    2017-08-10
  • CA服务器的搭建以及证书签署、dropbear的编译安装

    CA服务器的搭建以及证书签署、dropbear的编译安装 一、CA Server和Client: 1、CA server:创建私钥CA (1)   openssl的配置文件:/etc/pki/tls/openssl.conf   如果Client端的申请是来自不同的国家,则需要将下图中红色框内的三项,由“match”改为“opt…

    Linux干货 2016-09-23
  • vsphere虚拟机下的Linux在线移除硬盘后的报错处理(基于LVM)

    1)故障描述( vmware虚拟机,在线移除一块被设置为pv格式的硬盘后,提示unknown device错误): 说明:/dev/sdb1 /dev/sdc1 /dev/sdd1是组成/dev/vg_test/lvm_test的PV,这里我们模拟/dev/sdd1硬盘被直接断电了 [root@docker mnt]# pvdisplay…

    Linux干货 2016-07-29
  • 硬链接和软链接的区别

    硬链接和软链接在文件系统实现上的区别决定了两者之间功能上的不同,也就是说硬链接和软链在文件系统上两者实现的方式不同,让其各自具有不同的功能和特色,也决定了各自的优点和缺点。接下同文件系统上创建硬链接和软链接看各自的特点。 一文件系统上创建硬链接 下面命令是在文件系统上创建一个硬链接: ~]# ln test /testdir/t…

    Linux干货 2016-10-29
  • 学习宣言

     学习计划:参考N24学习时间与线路图,尽最大努力完成。 目标:学习好Linux,提升自我价值,找一份待遇好的工作。 宣言:每一次轻易的放弃,都是人生的一处败笔,为了梦想,加油!

    Linux资讯 2016-10-26
  • Linux磁盘管理(一)之分区、格式化、挂载使用

    磁盘管理(一)   本章节内容: 磁盘结构 分区类型   管理分区   管理文件系统   挂载设备   一、磁盘结构: 1、设备号码:  主设备号:major number, 标识设备类型 次设备号:minor number, 标识同一类型下的不同设备  &n…

    Linux干货 2016-08-26

评论列表(1条)

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

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