`
zengshaotao
  • 浏览: 756225 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

shell实例

    博客分类:
  • unix
 
阅读更多

1.用Shell编程,判断一文件是不是字符设备文件,如果是将其拷贝到 /dev 目录下。

参考程序:

#!/bin/sh

FILENAME=

echo Input file name:”

read FILENAME

if [ -c "$FILENAME" ]

then

cp $FILENAME /dev

fi

 

 3.设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx0130

参考答案:

#!/bin/sh

i=1

groupadd class1

while [ $i -le 30 ]

do

if [ $i -le 9 ] ;then

USERNAME=stu0${i}

else

USERNAME=stu${i}

fi

useradd $USERNAME

mkdir /home/$USERNAME

chown -R $USERNAME /home/$USERNAME

chgrp -R class1 /home/$USERNAME

i=$(($i+1))

done

 

4.编写shell程序,实现自动删除50个账号的功能。账号名为stud1stud50

参考程序:

#!/bin/sh

i=1

while [ $i -le 50 ]

do

userdel -r stud${i}

i=$(($i+1 ))

done

5.某系统管理员需每天做一定的重复工作,请按照下列要求,编制一个解决方案:

1)在下午4 :50删除/abc目录下的全部子目录和全部文件;

2)从早8:00~下午6:00每小时读取/xyz目录下x1文件中每行第一个域的全部数据加入到/backup目录下的bak01.txt文件内;

3)每逢星期一下午5:50/data目录下的所有目录和文件归档并压缩为文件:backup.tar.gz

4)在下午5:55IDE接口的CD-ROM卸载(假设:CD-ROM的设备名为hdc);

5)在早晨8:00前开机后启动。

参考答案:

解决方案:

1)用vi创建编辑一个名为prgxcrontab文件;

2prgx文件的内容:

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文件中的内容:

prgx;在每日早晨8:00之前开机后即可自动启动crontab

6.设计一个shell程序,在每月第一天备份并压缩/etc目录的所有内容,存放在/root/bak目录里,且文件名为如下形式yymmdd_etcyy为年,mm为月,dd为日。Shell程序fileback存放在/usr/bin目录下。

参考答案:

1)编写shell程序fileback

#!/bin/sh

DIRNAME=`ls /root | grep bak

if [ -z "$DIRNAME" ] ; then

mkdir /root/bak

cd /root/bak

else

cd /root/bak

fi

YY=`date +%y`

MM=`date +%m`

DD=`date +%d`

BACKETC=$YY$MM$DD_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

7.有一普通用户想在每周日凌晨零点零分定期备份/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 使生效。

8.设计一个Shell程序,在/userdata目录下建立50个目录,即user1user50,并设置每个目录的权限,其中其他用户的权限为:读;文件所有者的权限为:读、写、执行;文件所有者所在组的权限为:读、执行。

参考答案: 建立程序 Pro16如下:

#!/bin/sh

i=1

while [ i -le 50 ]

do

if [ -d /userdata ];then

mkdir -p /userdata/user$i

chmod 754 /userdata/user$i

echo "user$i"

let "i = i + 1" (或i=$(($i1))

else

mkdir /userdata

mkdir -p /userdata/user$i

chmod 754 /userdata/user$i

echo "user$i"

let "i = i + 1" (或i=$(($i1))

fi

done

 

 

 

[gaps3:64]/gaps > cd test

[gaps3:64]/gaps/test > ls -l

total 8

drwxr-xr-x    2 gaps     gapsgp          256 Apr 14 13:57 d1

drwxr-xr-x    2 gaps     gapsgp          256 Apr 14 14:00 d2

-rw-r--r--    1 gaps     gapsgp           21 Apr 14 13:56 f1.txt

[gaps3:64]/gaps/test >

 

[gaps3:64]/gaps > vi ttt.sh

"ttt.sh" 19 lines, 384 characters

#!/bin/bash

echo "test bak begin"

sourcepath="/gaps/test"

aimpath="/gaps/bak/date/test"

name=`ls -l $sourcepath | awk '{print $9}'`

for i in $name

  do

    pathname=`echo $sourcepath"/"$i`

    echo $pathname

    if [ -d "$pathname" ];then

      echo $i " is a deritory"

    elif [ -f "$pathname" ];then

      echo $i " is a file"

    else

      echo "error"

    fi

  done

echo $name

 

 

[gaps3:64]/gaps > sh ttt.sh

test bak begin

/gaps/test/d1

d1  is a deritory

/gaps/test/d2

d2  is a deritory

/gaps/test/f1.txt

f1.txt  is a file

d1 d2 f1.txt

 

#!/bin/bash

echo "test bak begin"

sourcepath="/gaps/test"

aimpath="/gaps/bak/"

name=`ls -l $sourcepath | awk '{print $9}'`

for i in $name

  do

    pathname=`echo $sourcepath"/"$i`

    echo $pathname

    if [ -d "$pathname" ];then

      echo $i " is a deritory"

    elif [ -f "$pathname" ];then

      datev=`date +"%Y-%m-%d"`

      tamp=$aimpath$datev

      echo $tamp

      relative=`dirname $pathname`

      tamp=$tamp$relative

      echo $tamp

      echo $pathname

      mkdir -p $tamp

      cp $pathname $tamp

    else

      echo "error"

    fi

  done

 

echo $name

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics