前提:
1、每位同学的IP地址为172.16.X.1, 子网掩码为255.255.0.0,网关为172.16.0.1,DNS服务器为172.16.0.1,主机名为stuX.example.com,其中X为你的座位号;
2、yum源为http://172.16.0.1/yum/{Server,Cluster,ClusterStorage,VT,errata};
1、安装操作系统,要求:
1)新建一个虚拟机,要求内存大于等于512M,虚拟磁盘大小为150G,网卡为桥接模式;
2)下载ftp://172.16.0.1/pub/images/boot.iso文件至物理机,并以之作为启动盘启动安装过程;
3)在安装启动界面boot:提示符后面输入(引号里面的内容):"linux ip=172.16.X.1 netmask=255.255.0.0 gateway=172.16.0.1 dns=172.16.0.1 ks=http://172.16.0.1/exam.cfg"
4)安装完成后需在事先排除系统故障,而后继续后面的题目;
a) root用户密码未知,需要修改为你所需要的密码;
b) grub损坏;
c) 系统会莫名其妙地重启;
###############################
按照要求做出1、2、3步 第3步中记得每一个选项一定要用空格,不然会出错的! 开机的时候你会看到系统停留在了黑屏。
接下来就是第4步,排错了!
首先要先找个系统盘做引导,进入bios把cd作为第一启动项,在提示符boot:输入linux rescue 进入紧急救援模式。
选择的时候一直回车,在看到选不选则进行网络配置的时候不去选择就可以了(第三个选项卡)。
然后就进入到了紧急救援模式在这个模式下输入:
#chroot /mnt/sysimage
#grub-install /dev/sda 装载grub
#cd /boot/grub
#ls 你会看到少了grub的主配置文件,我们现在来建立一个:
#vim grub.conf
内容是:
default=0
timeout=3
splashimage=(hd0,0)/grub/splash.xpm.gz
title RHEL 5.4
root (hd0,0)
kernel /vmlinuz-2.6.18-164.el5 root=/dev/vol0/root quiet
initrd /initrd-2.6.18-164.el5.img
在写kernel的时候如果不知道自己的内核是什么,可以在外面输入:
#ls /boot 查看一下
#vgs
#lvs
这两个可以查看根文件系统的位置
系统会自动重启是因为改变了inittab这个文件造成的
vim etc/inittab
把级别3后面改为对应的3
级别5改为对应的5
vim etc/rc.local
把里面的shutdown -r now 注释掉或者直接删掉
管理员的密码:
#passwd
输入新的密码就可以了
#sync 同步
#exit
#reboot 重启
2、创建一个空间大小为2G的RAID5设备,并且此设备具有一个空闲的备份磁盘;要求此设备开机时可以自动挂载至/backup目录;
###############################
#fdisk /dev/sda
在里面创建新的分区(扩展的)
然后创建4个分区 大小为1G
把4个分区的类型修改为fd
#partprobe /dev/sda
#fdisk -l 查看一下
#mdadm -C /dev/md0 -a yes -l 5 -n 3 -x 1 /dev/sda{5,6,7,8}
#mdadm -D /dev/md0 查看md设备的详细信息
#mke2fs -j -L RAID5 /dev/md0
#mkdir /backup
#vim /etc/fstab
在里面添加:
LABEL=RAID5 /backup ext3 defaults 0 0
#mount -a
#mount 查看一下是否挂载上去
3、创建一个由两个物理卷组成的大小为3G的卷组myvg,要求其PE大小为16M;而后在此卷组中创建一个大小为2G的逻辑卷lv1,此逻辑卷要能在开机后自动挂载至/users目录;
###############################
#fdisk /dev/sda
在里面你创建2个分区 一个为2G 一个为1G
修改类型为8e
#partprobe /dev/sda
#pvcreate /dev/sda{9,10}
#vgcreate -s 16m myvg /dev/sda{9,10}
#lvcreate -L 2G -n lv1 myvg
#lvdisplay /dev/myvg/lv1 查看一下
#mke2fs -j -L LV1 /dev/myvg/lv1
#mkdir /users
#vim /etc/fstab
在里面添加内容:
LABEL=LV1 /users ext3 defaults 0 0
#mount -a
#mount 查看一下
4、写一个小脚本,并执行;要求实现:
(1)新建ID为3306的组mysql;新建ID为3306的用户mysql,要求其家目录为/users/mysql,shell为/bin/nologin;
(2)新建组dba;新建用户gentoo,要求其家目录为/users/gentoo,密码同用户名;
(3)新建用户centos,其家目录为/users/centos,密码同用户名;
(4)用户gentoo和centos均以dba为其附加组;
###############################
vim hahaha.sh
在里面添加:
#! /bin/bash
#
groupadd -g 3306 mysql
useradd -u 3306 -d /users/mysql -s /sbin/nologin mysql
groupadd dba
useradd -G dba -d /users/gentoo gentoo
echo gentoo | passwd --stdin gentoo
useradd -G dba -d /users/centos centos
echo centos | passwd --stdin centos
#bash hahaha.sh 执行一下这个脚本
5、创建一个1G的分区,文件系统为ext3,卷标为DATA,块大小为1024,预留管理空间为磁盘分区的3%,要求开机后可以自动挂载至/data目录;
###############################
#fdisk /dev/sda
创建一个大小为1G的分区
#parprobe /dev/sda
#mke2fs -j -L DATA -b 1024 -m 3 /dev/sda11
#mkdir /data
#vim /etc/fstab
在里面添加:
LABEL=DATA /data ext3 default 0 0
#mount -a
#mount 查看一下
6、缩减前面创建的逻辑卷lv1的大小至1G;要求gentoo的家目录等不能丢失;
###############################
#umount /users
#e2fsck -f /dev/myvg/lv1
#resize2fs /dev/myvg/lv1 1G
#lvreduce -L 1G /dev/myvg/lv1
#mount -a
#mount 查看一下
#df -lh 查看缩减成功了没有
7、复制文件/etc/fstab至/data目录,其属主为root用户,属组为root组;要求此文件可以被任何人读取,可以被gentoo读写,但centos没有任何访问权限;
###############################
#cp /etc/fstab /data
#chown -R root:root /data/fstab
#chmod g+r /data/fstab
#setfacl -m u:gentoo:rw- /data/fstab
#setfacl -m u:centos:--- /data/fstab
8、配置centos用户能以root用户的身份执行useradd,userdel和usermod命令,而后以centos的身份创建一个新用户opensuse;
###############################
#visudo
在最后面添加:
centos ALL=(root) /usr/sbin/useradd, /user/sbin/usermod, /usr/sbin/userdel
#su - centos
#sudo /usr/sbin/useradd opensuse
输入一下密码
# tail /etc/passwd 查看一下
9、配置本地的yum源指向,而后安装mysql-server和httpd软件包;
###############################
#cd /etc/yum.repos.d/
#vim server.repo
在里面添加:
[base]
name=Server
baseurl=http://172.16.0.1/yum/Server
gpgcheck=0
#yum list all 测试一下
#yum install mysql-server httpd
#rpm -q mysql-server
#rpm -q httpd 验证一下
10、下载并编译安装axel;软件包所在的地址:ftp://172.16.0.1/pub/Sources/downloader;要求:
1)软件的默认安装目录为/usr/local/axel;
2)安装完成以后,所有用户可以直接执行axel命令,而不用输入命令的完整的路径;
###############################
#lftp 192.168.0.254/pub/Sources/downloader
#get axel
#bye
#tar xf axel
#cd axel
#./configure --prefix=/usr/local/axel
#make
#make install
#vim /etc/profile
添加 PATH=$PATH:/usr/local/axel/bin. /etc/profile
11、写一个脚本:
1)使用函数实现:
判断一个用户是否存在,用户名通过参数传递而来;
如果存在,就显示此用户的shell和UID
如果不存在,就说此用户不存在;
2)主调函数中,一直提示用户输入用户名,并显示;直到用户输入q或Q退出;
###############################
#vim myuseradd.sh
在里面写入:
#! /bin/bash
#
SHOWUSER() {
if grep "^${1}:" /etc/passwd &> /dev/null;then
echo "SHELL: `grep "^${1}:" /etc/passwd | cut -d: -f7`"
echo "UID: `grep "^${1}:" /etc/passwd | cut -d: -f3`"
else
echo "$1 is not alive."
fi
}
read -p "Username: " MYUSER
until [[ "$MYUSER" == [Qq] ]];do
SHOWUSER $MYUSER
read -p "Username:" MYUSER
done
#bash myuseradd.sh 运行一下
12、新建目录/backup/test,其属组为dba,且此组具有读写权限,其它用户没有任何权限;dba组成员在此目录中创建的文件的属组都需要是dba,且dba组中每个成员在此目录中只能删除自己的文件;
###############################
#mkdir /backup/test
#cd /backup
#chown :dba test
#chmod o=--- test/
#chmod g+w test/
#chmod g+s,o+t test/
13、配置当前主机内核参数,以允许在不同的网络接口间转发数据包;要求此项配置在重新启动系统后不会失效。
##############################
#vim /etc/sysctl.conf
把里面的net.ipv4.ip_forwark= 后面这个值改为1
#sysctl -p 立即生效
14、启用本机的VNC服务,并确保root可用可以使用redhat作为密码登录系统;
###############################
#yum install vnc-server
#vncserver & 启动
#vncpasswd 配置vnc的密码
如果感觉连上以后看着太难看,可以:
#cd .vnc/
#vim xstartup
把里面最后的那个twn改为gnome-session
#vncserver -kill :1
#vncserver & 把vnc关掉再重启一下
#chkconfig vncserver on 开机启动
15、配置本机每隔两天在凌晨3点20备份一次/etc目录,备份文件存放至/backup目录,文件名形如:etc-2011-11-20.tar.bz2;
###############################
#which tar 看看tar命令在什么地方
#crontab -e
在里面添加:
20 3 */3 * * /bin/tar jcf /backup/etc-`date+%F`.tar.bz2 /etc
16、找到/etc目录下属于root用户且至少7分钟没有访问过的普通文件,将它们复制到/tmp/test目录;/tmp/test目录需要自己事先创建;
###############################
#mkdir /tmp/test
#find /etc -user root -amin +7 -exec cp {} /tmp/test \;
17、为gentoo用户的家目录创建磁盘使用限额,要求其能够使用的磁盘空间最大为50M,软限制为30M;要求完成后验正其有效性;
###############################
#finger gentoo 查看gentoo的家目录在那
#vim /etc/fstab
在gentoo的家目录默认类型里输入usrquota
#mount -o remount /users 重新挂载
#quotacheck -cmu /users/
#quotaon /users
#edquata -u gentoo
在soft下30720 这个是软限制
后面hard下51200 这个是硬限制
可以通过:
#su - gentoo
#dd if=/dev/zero of=./bigfile.1 bs=1M count=30 这个命令创建大文件来验证一下
以下为选做题,至少选做其中一题;
18、(选做题)写一个脚本getinterface.sh,脚本可以接受参数(i,I,a),完成以下任务:
(1)使用以下形式:getinterface.sh [-i interface|-I IP|-a]
(2)当用户使用-i选项时,显示其指定网卡的IP地址;
(3)当用户使用-I选项时,显示其后面的IP地址所属的网络接口;
(4)当用户单独使用-a选项时,显示所有网络接口及其IP地址(lo除外);
##################################################################
#vim getinterface.sh
添加下面内容:
#!/bin/bash
SHOWIP () {
if ifconfig -a | grep "^[^[:space:]]" | cut -d' ' -f1 | grep "$1" &> /dev/null; then
ifconfig $1 | grep "inet addr:" | cut -d: -f2 | cut -d' ' -f1
else
return 12
fi
}
SHOWIF () {
if ifconfig -a | grep -B 2 $1 &> /dev/null; then
ifconfig -a | grep -B 2 $1 | head -1 | cut -d' ' -f1
[ $? -eq 0 ] && return 0
else
return 13
fi
}
while getopts ":i:I:a" OPT; do
case $OPT in
i)
SHOWIP $OPTARG
[ $? -eq 12 ] && echo "Device error"
;;
I)
SHOWIP $OPTARG
[ $? -eq 13 ] && echo "Wrong IP."
;;
a)
for ETH in `ifconfig -a | grep "^[^[:space:]]" | cut -d' ' -f1 | grep -E -v "lo|sit0"`; do
echo "$ETH" `SHOWIP $ETH`"
done
;;
*)
echo "Usage: getinterface.sh {-i interface|-I IP|-a}"
exit 5
;;
esac
done
19、(选做题)写一个脚本,完成以下功能:
1)此脚本能反复地提示用户输入一个二进制命令的名字,如mount、cp等,用户每输入一个命令,则按照后面的要求将其复制到指定的目录;如果命令不存在,则提示用户命令不存在,请继续输入;如果用户输入的为q或者Q,则退出脚本;
说明:这些文件位于/bin, /sbin, /usr/bin, /usr/sbin目录中,但具体哪个命令在哪个目录中,可以使用which命令查看到。
2)如果不存在,则创建空目录/tmp/mylinux,否则,提示用户删除y/n;如果用户选择不删除,则退出;如果用户选择了删除,则在/tmp/mylinux中创建子目录bin, sbin, usr, usr/bin, usr/sbin
3)将对应的二进制文件复制至相应的/tmp/mylinux目录的某个子目录中去。比如,将/bin/cut复制到/tmp/mylinux/bin目录,把/sbin/mke2fs复制到/tmp/mylinux/sbin目录中;
################################################################
#vim binup.sh
添加下面的内容:
#!/bin/bash
read -p "Please input a commnd :" I
until [ "$I" = "q" ] || [ "$I" = "Q" ]; do
which $I &> /dev/null
if [ ! $? -eq 0 ];then
echo "this commnd is not alive " && read -p "INPUT" I
else
if [ ! -d /tmp/mylinux ]; then
mkdir /tmp/mylinux
else
read -p "are you want delet y/n" SWITCH
if [ "$SWITCH" == "y" ]; then
mkdir -p /tmp/mylinux/{bin,sbin,usr/{bin,sbin}}
echo " mkdir done"
elif [ "$SWITCH" == "n" ]; then
echo "quiting"
exit 2
else
echo "wrong"
exit 3
fi
fi
CMD=`which $I | grep -o "/.*"`
CMDPATH=`which $I | grep -o "/.*" | sed 's@\(.*\)/[^[:space:]]\{1,\}@\1@g'`
[ -d /tmp/mylinux/$CMDPATH ] || mkdir -p /tmp/mylinux/$CMDPATH
[ ! -e /tmp/mylinux/$CMD ] && cp $CMD /tmp/mylinux/$CMDPATH && echo "copy $CMD done
fi
read -p "please input a commnd:" I
done
exit