1.用Shell编程,判断一文件是不是字符设备文件,如果是将其拷贝到 /dev 目录下。
参考程序:
#!/bin/sh
FILENAME=
echo “Input file name:”
read FILENAME
if [ -c “$FILENAME” ]
then
cp $FILENAME /dev
fi
2.设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx从01到30。
参考答案:
#!/bin/sh
i=1
groupadd class1
while [ $i -le 30 ]
do
if [ i−le9];thenUSERNAME=stu0i -le 9 ] ;thenUSERNAME=stu0i−le9];thenUSERNAME=stu0{i}
else
USERNAME=stu${i}
fi
useradd USERNAMEmkdir/home/USERNAMEmkdir /home/USERNAMEmkdir/home/USERNAME
chown -R USERNAME/home/USERNAME /home/USERNAME/home/USERNAME
chgrp -R class1 /home/USERNAMEi=USERNAMEi=USERNAMEi=(($i+1))
done
3.编写shell程序,实现自动删除50个账号的功能。账号名为stud1至stud50。
参考程序:
#!/bin/sh
i=1
while [ i−le50]douserdel−rstudi -le 50 ]douserdel -r studi−le50]douserdel−rstud{i}
i=((((((i+1 ))
done
4.某系统管理员需每天做一定的重复工作,请按照下列要求,编制一个解决方案:
(1)在下午4 :50删除/abc目录下的全部子目录和全部文件;
(2)从早8:00~下午6:00每小时读取/xyz目录下x1文件中每行第一个域的全部数据加入到/backup目录下的bak01.txt文件内;
(3)每逢星期一下午5:50将/data目录下的所有目录和文件归档并压缩为文件:backup.tar.gz;
(4)在下午5:55将IDE接口的CD-ROM卸载(假设:CD-ROM的设备名为hdc);
(5)在早晨8:00前开机后启动。
参考答案:
解决方案:
(1)用vi创建编辑一个名为prgx的crontab文件;
(2)prgx文件的内容:
50 16 * * * rm -r /abc/*
0 8-18/1 * * * cut -f1 /xyz/x1 >;>; /backup/bak01.txt
50 17 * * * tar zcvf backup.tar.gz /data
55 17 * * * umount /dev/hdc
(3)由超级用户登录,用crontab执行 prgx文件中的内容:
root@xxx:#crontab prgx;在每日早晨8:00之前开机后即可自动启动crontab。
5.设计一个shell程序,在每月第一天备份并压缩/etc目录的所有内容,存放在/root/bak目录里,且文件名为如下形式yymmdd_etc,yy为年,mm为月,dd为日。Shell程序fileback存放在/usr/bin目录下。
参考答案:
(1)编写shell程序fileback:
#!/bin/sh
DIRNAME=
ls /root | grep bak
if [ -z \”DIRNAME\”];thenmkdir/root/bakcd/root/bakfiYY=‘date+MM=‘date+DD=‘date+BACKETC=DIRNAME\” ] ; thenmkdir /root/bakcd /root/bakfiYY=`date +%y`MM=`date +%m`DD=`date +%d`BACKETC=DIRNAME\”];thenmkdir/root/bakcd/root/bakfiYY=‘date+MM=‘date+DD=‘date+BACKETC=YYMMMMMMDD_etc.tar.gz
tar zcvf $BACKETC /etc
echo “fileback finished!”
(2)编写任务定时器:
echo “0 0 1 * * /bin/sh /usr/bin/fileback” >; /root/etcbakcron
crontab /root/etcbakcron
或使用crontab -e 命令添加定时任务:
0 1 * * * /bin/sh /usr/bin/fileback
6.有一普通用户想在每周日凌晨零点零分定期备份/user/backup到/tmp目录下,该用户应如何做?
参考答案:
(1)第一种方法:
用户应使用crontab –e 命令创建crontab文件。格式如下:
0 0 * * sun cp –r /user/backup /tmp
(2)第二种方法:
用户先在自己目录下新建文件file,文件内容如下:
0 * * sun cp –r /user/backup /tmp
然后执行 crontab file 使生效。
7.设计一个Shell程序,在/userdata目录下建立50个目录,即user1~user50,并设置每个目录的权限,其中其他用户的权限为:读;文件所有者的权限为:读、写、执行;文件所有者所在组的权限为:读、执行。
参考答案: 建立程序 Pro16如下:
i=1
while [ i -le 50 ]
do
if [ -d /userdata ];then
mkdir -p /userdata/userichmod754/userdata/userichmod 754 /userdata/userichmod754/userdata/useri
echo “useri”let“i=i+1″(或i=i”let “i = i + 1″ (或i=i”let“i=i+1″(或i=((i+1))elsemkdir/userdatamkdir−p/userdata/useri+1))elsemkdir /userdatamkdir -p /userdata/useri+1))elsemkdir/userdatamkdir−p/userdata/useri
chmod 754 /userdata/useriecho“useriecho “useriecho“useri”
let “i = i + 1″ (或i=((((((i+1))
fi
done
8、mysql备份实例,自动备份mysql,并删除30天前的备份文件
#auto backup mysql
#wugk 2012-07-14
#PATH DEFINE
BAKDIR=/data/backup/mysql/
date +%Y-%m-%d
MYSQLDB=www
MYSQLPW=backup
MYSQLUSR=backup
if[ $UID -ne 0 ];then
echo This script must use administrator or root user ,please exit!
sleep 2
exit 0
fi
if[ ! -d $BAKDIR ];then
mkdir -p $BAKDIR
else
echo This is $BAKDIR exists ,please exit ….
sleep 2
exit
fi
###mysqldump backup mysql
/usr/bin/mysqldump -uMYSQLUSR−pMYSQLUSR -pMYSQLUSR−pMYSQLPW -d $MYSQLDB >/data/backup/mysql/
date +%Y-%m-%d
/www_db.sql
cd $BAKDIR ; tar -czf www_mysql_db.tar.gz *.sql
cd $BAKDIR ;find . -name “*.sql” |xargs rm -rf[ $? -eq 0 ]&&echo “This
date +%Y-%m-%d
RESIN BACKUP is SUCCESS”
cd /data/backup/mysql/ ;find . -mtime +30 |xargs rm -rf