Chinaunix首页 | 论坛 | 博客
  • 博客访问: 444274
  • 博文数量: 40
  • 博客积分: 6011
  • 博客等级: 准将
  • 技术积分: 1490
  • 用 户 组: 普通用户
  • 注册时间: 2006-11-06 10:50
文章分类

全部博文(40)

文章存档

2011年(1)

2008年(39)

我的朋友

分类: LINUX

2008-05-31 00:18:41

1:在shell编程中的变量。
shell 变量(转换shell后就失效),环境变量(改变shell后仍有效)。Bash和pdksh中给变量赋值得方法一样(变量名后面跟上等号和变量值,如: var1=1,等号两边不能有空格),tcsh中使用:set var1 = 5(等号两边可以有空格也可没有) 。
对shell变量进行数字运算,使用expr命令:如,expr $a + $b (注意+两边的空格);expr 2 \* \( 3 + 4 \)
  特殊变量  

      $#:存储shell程序中命令行参数的个数
      $?:存储shell中上一个程序执行的返回值(0表示命令执行成功,非0有问题)
      $0:存储shell程序自己的名称
      $[1-n]:存储第[1-n]个命令行参数
      $*:存储shell脚本的所有参数(不包含$0)
      $@:存储shell脚本的所有命令行参数
      $$:存储shell脚本的进程号(pid)
      $!:存储上一个后台执行命令的进程号(pid)

       
2:使用哪一种命令外壳执行shell程序
    第一: 命令解释器  shell文件名。如:bash file1.sh
    第二:在shell脚本中的的首行指明由谁执行。如:#!/bin/bash
如果第一行非空字符为#!则使用后面指名的shell,如果第一行非空字符为#则使用C外壳,如果第一行非空字符不为#则使用B外壳。
    第三:在pdksh和bash下使用“.  文件名”(点后有空格),在tcsh下使用“source 文件名”
    第四:命令替换:略。
3:从标准输入读取变量的值
 可通过命令行参数以及交互式输入变量(read),如:read  a 。
bash的流程控制语句
1)条件判断
 . if-then语句,格式如下:
   if command_1
   then
        command_2
        command_3
    fi
    command_4
   在if-then语句中使用了命令返回值$?,即当command_1执行成功时才执行command_2 和command_3,而command_4总是执行.
   . if-then-else语句
   if command_1
   then
        command_2
   else
        command_3
   fi         
   .if嵌套及elif结构
        if command
        then
            command
        else
            if command
            then
                command
            else
                if command
                then
                    command
                fi
            fi
        fi
        改进:使用elif结构
        if command
        then
            command
        elif    command
        then   
            command
        elif    command
        then
            command
        fi
        elif结构同if结构类似,但结构更清淅,其执行结果完全相同.
.bash和pdksh中的case语句规则如下:
    case string1 in
       str1 )
         commands;;
       str2 )
         commands;;
       * )――――――――――――――缺省情况
         commands;;
    esac
2)循环控制语句(详细语法解释略)
.for语句
for var1 in list(用空格隔开各个选项)
    do
        commands
    done
或者:for var        列表需要在命令行输入
     do
        commands
     done
.while语句
while 表达式
do
           commands
        done
3)shift:移动shell程序的命令行参数
  语法格式:shift [n]
  如果有参数n,shift重命名位置参数,参数n+1对应与$1,n+2应与$2…,若为0则参数不变;若无参数则莫认为1,则参数应则参数应为非负数。
4)select 命令
  语法格式:
       select variable in list-of-items
       do
          commands
       done
  常 用于显示用户选择的被编号的菜单项,在标准输出中显示in之后的列表项,在每一项之前由数值作为前导。如果in被省略,则使用位置参数值。在显示列表项之 后显示PS3提示符提示用户输入内容,select把值赋给变量。若用户输入空行则菜单被重新显示。如果读入EOF(CTRL+D)则命令终止, select的退出状态是最后一条命令的执行结果。若无命令执行返回0。
   例:
   select mychoice in size information cfiles
   do
      case $mychoice in
        size)
          ls –s;;
        information)
          ls –l;;
        cfiles)
          ls *.c;;
      esac
   done
5)exit有两个作用:一是停止程序中其他命令的执行,二是设置程序的退出状态.n为返回值
   命令格式:exit [n]
6)break命令:强制程序从for,while或until循环中退出,n为退出循环的层次
   命令格式:break [n]
test的使用
. 使用test命令进行进行条件测试
      格式: test conditions
      test在以下四种情况下使用:
            a. 字符比较
            b. 两个整数值的比较
            c. 文件操作,如文件是否存在及文件的状态等
            d. 逻辑操作,可以进行and/or,与其他条件联合使用
      a. 测试字符数据: shell变量通常民政部下均作为字符变量
        str1 = str2 二者相长,相同
        str1 != str2    不同
        -n string   string不为空(长度不为零)
        -z string   string为空
        string      string不为空
    例:
        $ str1=abcd #在含有空格时必须用引号括起来
        $ test $str1=abcd
        $ echo $?
        0
        $ str1="abcd "
        $ test $str1=abcd
        $ echo $?
        1
    注意: 在test处理含有空格的变量时最好用引号将变量括起来,否则会出现错误的结果,因为shell在处理命令行时将会去掉多余的空格,而用引号括起来则可以防止shell去掉这些空格. 例:
            $ str1="    "
            $ test $str1
            $ echo $?
            1
            $ test "$str1"
            $ echo $?
            0
            $ test -n $str1
            test: argument expected
            $ test -n "$str1"
            $ echo $?
            0
           
    b. 整数测试: test与expr相同,可以将字符型变量转换为整数进行操作,expr进行       整数的算术运算,而test则进行逻辑运算.
         表达式         说明
         ---------------------------------------
         int1 -eq int2      相等?
         int1 -ne int2      不等?
         int1 -gt int2      int1 > int2 ?  
         int1 -ge int2      int1 >= int2 ?
         int1 -lt int2      int1 < int2 ?
         int1 -le int2      int1 <= int2 ?
         例:
            $ int1=1234
            $ int2=01234
            $ test $int1 -eq $int2
            $ echo $?
            0     
      c. 文件测试:检查文件状态如存在及读写权限等
         -r filename    用户对文件filename有读权限?
         -w filename    用户对文件filename有写权限?
         -x filename    用户对文件filename有可执行权限?
         -f filename    文件filename为普通文件? 【判断文件是否存在】
         -d filename    文件filename为目录?
         -c filename    文件filename为字符设备文件? 
         -b filename    文件filename为块设备文件?
         -s filename    文件filename大小不为零?
         -t fnumb   与文件描述符fnumb(默认值为1)相关的设备是一个终端设备?
      d. 测试条件之否定,使用!
        例:
            $ cat /dev/null > empty
            $ test -r empty
            $ echo $?
            0
            $ test -s empty
            1
            $ test ! -s empty
            $ echo $?
            0
      e. 测试条件之逻辑运算
        -a  And
        -o  Or
        例: $ test -r empty -a -s empty
            $ echo $?
            1
      f. 进行test测试的标准方法
         因为test命令在 shell编程中占有很重要的地位,为了使shell能同其他编程语言一样便于阅读和组织, Bourne Shell在使用test测试时使用了另一种方法:用方括号将整个test测试括起来:
         $ int1=4
         $ [ $int1 -gt 2 ]
         $ echo $?
         0
bash编程实例
实例1:判断/etc/shadow是否可执行
#!/bin/bash
if test -x /etc/shadow
then
        echo "the file is writeable"
else
        echo "the file is not writeable!"
fi
实例2:简单的菜单程序

#!/bin/bash

if test -x /etc/shadow
then
        echo "the file is writeable"
else
        echo "the file is not writeable!"
fi

实例3:完整的系统脚本/etc/rc.d/init.d/nfs

 

#!/bin/sh

#

# nfs This shell script takes care of starting and stopping

# the NFS services.

#

# chkconfig: - 60 20

# description: NFS is a popular protocol for file sharing across TCP/IP \

# networks. This service provides NFS server functionality, \

# which is configured via the /etc/exports file.

# probe: true


# Source function library.

. /etc/rc.d/init.d/functions
# Source networking configuration.

if [ ! -f /etc/sysconfig/network ]; then
    exit 0
fi
. /etc/sysconfig/network
# Check that networking is up.

[ ${NETWORKING} = "no" ] && exit 0
[ -x /usr/sbin/rpc.nfsd ] || exit 0
[ -x /usr/sbin/rpc.mountd ] || exit 0
[ -x /usr/sbin/exportfs ] || exit 0
# Don't fail if /etc/exports doesn't exist; create a bare-bones version and continue.

[ -s /etc/exports ] || \
    { echo "#" > /etc/exports && chmod u+rw,g+r,o+r /etc/exports ; } || \
    { echo "/etc/exports does not exist" ; exit 0 ; }

# Number of servers to be started by default

RPCNFSDCOUNT=8
# NFSv3 only if kernel >= 2.2.18

OS_RELEASE=`uname --release`
OS_RELEASE_MINOR=`echo "$OS_RELEASE" | sed 's/\(^[0-9]\)\.\([0-9]*\).*/\2/'`
OS_RELEASE_VERSION=`echo "$OS_RELEASE" | sed
's/\(^[0-9]\)\.\([0-9]*\)\.\([0-9]*\).*/\3/'`
if [ "$OS_RELEASE_MINOR" -gt 2 ]; then
    RPCMOUNTDOPTS=
elif [ "$OS_RELEASE_MINOR" -eq 2 -a "$OS_RELEASE_VERSION" -ge 18 ]; then
    RPCMOUNTDOPTS=
else
    RPCMOUNTDOPTS="--no-nfs-version 3"Z
fi
if [ -n "$MOUNTD_PORT" ]; then
    RPCMOUNTDOPTS="$RPCMOUNTDOPTS --port $MOUNTD_PORT"
fi
# See how we were called.

case "$1" in
  start)
    # Start daemons.

    action "Starting NFS services: " /usr/sbin/exportfs –r
    if [ -x /usr/sbin/rpc.rquotad ] ; then
        echo -n "Starting NFS quotas: "
        daemon rpc.rquotad
        echo
    fi
    echo -n "Starting NFS mountd: "
    daemon rpc.mountd $RPCMOUNTDOPTS
    echo
    echo -n "Starting NFS daemon: "
    daemon rpc.nfsd $RPCNFSDCOUNT
    echo
    touch /var/lock/subsys/nfs
    ;;
  stop)
    # Stop daemons.

    echo -n "Shutting down NFS mountd: "
    killproc rpc.mountd
    echo
    echo -n "Shutting down NFS daemon: "
    killproc nfsd
    echo
    action "Shutting down NFS services: " /usr/sbin/exportfs –au
    if [ -x /usr/sbin/rpc.rquotad ] ; then
        echo -n "Shutting down NFS quotas: "
        killproc rpc.rquotad
        echo
    fi
    rm -f /var/lock/subsys/nfs
    ;;
  status)
    status rpc.mountd
    status nfsd
    if [ -x /usr/sbin/rpc.rquotad ] ; then
        status rpc.rquotad
    fi
    ;;
  restart)
    echo -n "Restarting NFS services: "
    echo -n "rpc.mountd "
    killproc rpc.mountd
    daemon rpc.mountd $RPCMOUNTDOPTS
    /usr/sbin/exportfs –r
    touch /var/lock/subsys/nfs
    echo
    ;;
  reload)
    /usr/sbin/exportfs –r
    touch /var/lock/subsys/nfs
    ;;
  probe)
    if [ ! -f /var/lock/subsys/nfs ] ; then
      echo start; exit 0
    fi
    /sbin/pidof rpc.mountd >/dev/null 2>&1; MOUNTD="$?"
    /sbin/pidof nfsd >/dev/null 2>&1; NFSD="$?"
    if [ $MOUNTD = 1 -o $NFSD = 1 ] ; then
      echo restart; exit 0
    fi
    if [ /etc/exports -nt /var/lock/subsys/nfs ] ; then
      echo reload; exit 0
    fi
    ;;
  *)
    echo "Usage: $0 {start|stop|status|restart|reload}"
    exit 1
esac
exit 0

判断:

#!/bin/sh

  myPath="/var/log/httpd/"
  myFile="/var /log/httpd/access.log"
  #这里的-x 参数判断$myPath是否存在并且是否具有可执行权限

  if [ ! -x "$myPath"]; then
  mkdir "$myPath"
  fi
  #这里的-d 参数判断$myPath是否存在

  if [ ! -d "$myPath"]; then
  mkdir "$myPath"
  fi
  #这里的-f参数判断$myFile是否存在

  if [ ! -f "$myFile" ]; then
  touch "$myFile"
  fi
  #其他参数还有-n,-n是判断一个变量是否是否有值

  if [ ! -n "$myVar" ]; then
  echo "$myVar is empty"
  exit 0
  fi
  #两个变量判断是否相等

  if [ "$var1" = "$var2" ]; then
  echo '$var1 eq $var2'
  else
  echo '$var1 not eq $var2'
  fi

阅读(1454) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2008-10-27 13:35:38

真的是简单实用 入门版 谢谢