开始写shell了

  zte 的 project 中使用shell 语言写了几个脚本,总结一下

1. A 机器需要 ssh 到B主机,执行B主机上的一个脚本,并且将 执行的参数传过去,可以直接

   ssh root@$phy_host "/opt/zxve/bandwidth.sh $vm_name $ACTION $TRAFFIC_IN_SIZE $TRAFFIC_OUT_SIZE"  >> /tmp/NET_TRAFFIC.log

 其实 ssh 命令是直接可以传递参数的,到了B主机执行的脚本,我们可以使用$1,$2 方式得到参数

2.为了A主机SSH 到B主机 不输入密码,我们使用了 ssh-keygen -t dsa 生产公钥的方式

 详见

http://shutiao2008.iteye.com/blog/315102

http://jakson.homeip.net/joomla/index.php?option=com_content&view=article&id=159:ssh-keygen----key-&catid=67:linux-setting-ssh&Itemid=125

http://hi.baidu.com/wangpeng1314/blog/item/ef3bb901fb9987007aec2cec.html

http://rttech.spaces.live.com/Blog/cns!1D57B9457EA24D18!206.entry

3. 当A主机到B主机 SSH 不需要密码的时候,有时候A主机会 提示 unkown host

比如A主机 需要SSH到 B主机 ,则这样修改A主机的:

  /etc/ssh/ssh_config 中的
#  StrictHostKeyChecking ask 改成
   StrictHostKeyChecking no
     这样多此一举的询问就不在了。

4. 使用  existing_machine_num=`echo $existing_machine_uuids | wc -w`  关键是 “ · ” 的使用

  在接下的shell中就可以使用 $existing_machine_num 得到值了, ·命令· 相当于在控制台执行命令

 5.expr 命令的使用

expr命令一般用于整数值,但也可用于字符串。一般格式为:
expr argument operator argument
expr也是一个手工命令行计数器。
$expr 10 + 10
20
$expr 1500 + 900
2500
$expr 30 / 3
10
$expr 30 / 3 / 2
5
(注意运算符左右都有空格 ,如果没有空格表示是字符串连接)
使用乘号时,必须用反斜线屏蔽其特定含义。因为shell可能会误解显示星号的意义。
$expr 30 * 3
90

数值测试
可以用expr测试一个数。如果试图计算非整数,将返回错误。
$rr=1.1
$expr $rr + 1
expr: non-numeric argument
$rr=2
$expr $rr + 1
3
(注意:这个例子与原文不同)
这里需要将一个值赋予变量(不管其内容如何),进行数值运算,并将输出导入dev/null,
然后测试最后命令状态,如果为0,证明这是一个数,其他则表明为非数值。
$value=12
$expr $value + 10 > /dev/null 2>&1
$echo $?
0
这是一个数。
$value=hello
$expr $value + 10 > /dev/null 2>&1
$echo $?
2
这是一个非数值字符。

expr也可以返回其本身的退出状态,不幸的是返回值与系统最后退出命令刚好相反,成
功返回1,任何其他值为无效或错误。下面的例子测试两个字符串是否相等,这里字符串为
“hello”和“hello”。
$value=hello
$expr $value = "hello"
1
$echo $?
0
expr返回1。不要混淆了,这表明成功。现在检验其最后退出状态,返回0表示测试成功,
“hello”确实等于“hello”。

模式匹配
expr也有模式匹配功能。可以使用expr通过指定冒号选项计算字符串中字符数。.*意即任
何字符重复0次或多次。
$value=accounts.doc
$expr $value : '.*'
12

在expr中可以使用字符串匹配操作,这里使用模式. d o c抽取文件附属名。
$expr $value : '(.*).doc'
accounts

shell 中数组


$varname[0]=value1
$varname[1]=value2
....
来定义

$echo ${varname[0]}
方式来引用

从位置处抓取字串

shell>> expr substr "this is a test" 3 5
is is

数字串 only the first character

shell>> expr index "testforthegame" e
2
  
字串真实重现


shell>> expr quote thisisatestformela
thisisatestformela

6.eval

在 shell 脚本中经常能见到 eval 工具的使用,先前总是不能对其真正的理解,最近查看了一些资料,并做了几个测试的例子,现在终于搞清楚它的意思了

  它相当于 c 语言中的宏定义,当在一个赋值语句的前面加上 eval 时,它就会将 后面表达式中以 $ 开头的所有变量进行整体替换


例如:

var1="1234 4556"
tmp=var

eval test="$"$var"1"

echo  $test

那么就会在屏幕上显示出 :

            1234 4556

      从昨天开始研究eval一直没明白什么意思,网上关于这个的资料很多,可能是我的理解有问题吧。下面把eval的用法总结一下:
1、相当于C语言中的宏定义
    当在一个赋值语句的前面加上 eval 时,它就会将 后面表达式中以 $ 开头的所有变量进行整体替换。

例1:(这里参考http://www.linux-cn.com/html/linux/other/20070509/37717.html)

$ var="1234 4556"
$ tmp=var

$ eval test='$'$tmp (这里只是参数传递)
$ echo $test
那么就会在屏幕上显示出 :
$
1234 4556
例2:(这里参考http://www.freebsd.org.hk/html/csh/no3-8-11.html)
$ tmp='ls -l; date'
$ eval $tmp
total 83292
drwx------   6 a    a         4096 2007-07-13 18:23
.......
.......
.......
drwxr-xr-x  13 a    a         4096 2007-11-28 09:48
drwx------   9 a    a         4096 2007-11-22 17:51
四 11月 29 13:57:09 CST 2007
2、用在函数中时
例:(这里参考http://bbs.chinaunix.net/thread-932524-1-1.html)
getc ()
{
stty raw
tmp=`dd bs=1 count=1 2>/dev/null`
eval $1='$tmp'
stty cooked
}
解释1:
调用的例子:
getc var
用参数$1中保存的变量名(上例中是var)来存取到的键值,这里用eval是因为=左边的$1需要先扩展成var, 然后再对var赋值,跟=右边的东西没有关系。
將 eval 看成“重新解釋并執行其參數”就比較好理解了。
 
解释2:
我們看看這句: eval $1='$tmp'
因為 shell 的變量定義中,var_name 不能含有 $ 的,所以不能直接跑 $1=$tmp。
當 $1='$tmp' 作為 eval 參數時,先會解釋為 xxx=$tmp (假設 $1 的值為 xxx),
然後丟給 eval 再執行一次,就得 xxx=yyy (假設 $tmp 的值為 yyy)
 
 
 

7.if  写法

 A .if else

#!/bin/sh
# cript to see whether argument is positive
#
echo - n "input number:"
read num
 if [ $num = 1 ] ; then
 echo "input number is 1"
 else
 echo "other number!"
 fi
 

 B.

  if

   else if

 else

#!/bin/sh
# cript to see whether argument is positive
#
echo - n "input number:"
read num
 if [ $num = 1 ]; then
 echo "input number is 1"
 elif [ $num = 2 ]; then
 echo "input number is 2"
 else
 echo "other number!"
 fi
 

8. 打印输入记录最后一个字段的值

echo
 "/one/two/three/last"
 | awk -v FS
=
"/"
 '{print $NF}'

猜你喜欢

转载自8366.iteye.com/blog/795070