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://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}'