功能说明:设置指令的别名。
语 法:alias[别名]=[指令名称]
补充说明:用户可利用alias,自定指令的别名。若仅输入alias,则可列出目前所有的别名设置。 alias的效力仅及于该次登入的操作。若要每次登入是即自动设好别名,可在/etc/profile或自己的~/.bashrc中设定指令的别名。
还有,如果你想给每一位用户都生效的别名,请把alias la='ls -al' 一行加在/etc/bashrc最后面,bashrc是环境变量的配置文件 /etc/bashrc和~/.bashrc 区别就在于一个是设置给全系统一个是设置给单用户使用.
参 数:若不加任何参数,则列出目前所有的别名设置。
取消别名的方法是在命令前加\,比如 \mkdir[root@linuxso.com ~]#alias
alias tomcat_stop='sh /usr/local/tomcat/bin/shutdown.sh'
(二)Linux Shell语法速查表(用C语言语法来作对比)
虽然学过Linux Shell编程,但由于编写Shell脚本的机会实在是比较少(通常在项目初期搭建开发环境时编写得比较多一些),所以一些语法久而久之就会忘了,一个简单的语法去翻书效率实在是慢,所以就个人整理了一个表格,由于我用的编程语言是C/C++,所以在编程的时候往往脑海里面首先浮现的是用C语言怎么去编写它,所以我干脆拿C语言的语法来和Shell编程的语法作个对比表,这样查起来就方便了,哈:
要实现的功能 | C语言编程 | Linux Shell脚本编程 |
程序/脚本的参数传递 | int main(int argc, char** argv) { if (argv != 4) { printf( “Usage: %s arg1 arg2 arg3”, argv[0] ); return 1; }
printf(“arg1:%s/n”,argv[1]); printf(“arg2:%s/n”,argv[2]); printf(“arg3:%s/n”,argv[3]); return 0; } | #!/bin/sh
if [ $# -lt 3 ]; then echo "Usage: `basename $0` arg1 arg2 arg3" >&2 exit 1 fi
echo "arg1: $1" echo "arg2: $2" echo "arg3: $3" exit 0 |
int main(int argc, char** argv) { int i; for (i=1; i<=argc;i++) { printf(“arg:%s/n”,argv[i]); } return 0; } | #!/bin/sh
while [ $# -ne 0 ] do echo "arg: $1" shift done | |
逻辑/数值运算 | if (d == 0) | if [ "$D" -eq "0" ] ; then |
if (d != 0) | if [ "$D" -ne "0" ] ; then | |
if (d > 0) | if [ "$D" -gt "0" ] ; then | |
if (d < 0) | if [ "$D" -lt "0" ] ; then | |
if (d <= 0) | if [ "$D" -le "0" ] ; then | |
if (d >= 0) | if [ "$D" -ge "0" ] ; then | |
字符串比较 | if (strcmp(str,”abc”)==0) { } | if [ "$STR" != "abc" ]; then fi |
输入和输出 | scanf(“%d”,&D); | read D |
printf( “%d”, D); | echo –n $D | |
printf( “%d”,D); | echo $D | |
printf( “Press any to continue...”); char ch=getchar(); printf( “/nyou pressed: %c/n”, ch ); | #!/bin/sh
getchar() { SAVEDTTY=`stty -g` stty cbreak dd if=/dev/tty bs=1 count=1 2> /dev/null stty -cbreak stty $SAVEDTTY }
echo -n "Press any key to continue..." CH=`getchar` echo "" echo "you pressed: $CH" | |
| read D <&3 | |
程序/脚本的控制流程 | if (isOK) { //1 } else if (isOK2) { //2 } else { //3 } | if [ isOK ]; then #1 elif [ isOK2 ]; then #2 else #3 fi |
switch (d) { case 1: printf(“you select 1/n”); break; case 2: case 3: printf(“you select 2 or 3/n”); break; default: printf(“error/n”); break; }; | case $D in 1) echo "you select 1" ;; 2|3) echo "you select 2 or 3" ;; *) echo "error" ;; esac | |
for (int loop=1; loop<=5;loop++) { printf( “%d”, loop); } | for loop in 1 2 3 4 5 do echo $loop done | |
do { sleep(5); } while( !isRoot ); | IS_ROOT=`who | grep root` until [ "$IS_ROOT" ] do sleep 5 done | |
counter=0; while( counter < 5 ) { printf( “%d/n”, counter); counter++; } | COUNTER=0 while [ $COUNTER -lt 5 ] do echo $COUNTER COUNTER=`expr $COUNTER + 1` done | |
while (1) { } | while : do done | |
break; | break或break n,n表示跳出n级循环 | |
continue; | continue | |
函数与过程的定义 | void hello() { printf( “hello/n” ); } … //函数调用 hello(); | hello() { Echo “hello” } 或者 function hello() { Echo “hello” } … #函数调用 hello |
函数的参数和返回值 | int ret = doIt(); if (ret == 0) { printf( “OK/n” ); } | doIt if [ “$?” –eq 0 ] ; then echo “OK” fi 或者 RET = doIt if [ “$RET” –eq “0” ] ; then echo “OK” fi |
int sum(int a,int b) { return a+b; } int s = sum(1,2); printf(“the sum is: %d/n”, s); | sum() { echo -n "`expr $1 + $2`" } S=`sum 1 2` echo "the sum is: $S" | |
bool isOK() { return false; } if (isOK) { printf( “YES/n” ); } else { printf( “NO/n” ); } | isOK() { return 1; } if isOK ; then echo "YES" else echo "NO" fi |
(三) Shell的函数返回值问题
今天有个开发人员写了这么一段shell(当然我把业务给省略了,真实情况当然没这么简单):
| #!/bin/sh |
|
| function foo(){ |
|
result=$(echo $1) |
|
return $result |
| } |
|
| function invoker(){ |
|
foo $1 |
|
return $? |
| } |
|
| invoker 13 |
| echo $? |
| invoker 1011 |
| echo $? |
大家猜想一下结果,开发人员认为应该打印13和1011,但结果却是13和243,打开shell的debug信息:
| + invoker 13 |
| + foo 13 |
| ++ echo 13 |
| + result=13 |
| + return 13 |
| + return 13 |
| + echo 13 |
| 13 |
| + invoker 1011 |
| + foo 1011 |
| ++ echo 1011 |
| + result=1011 |
| + return 1011 |
| + return 243 |
| + echo 243 |
| 243 |
大家发现返回13的时候正常而1011怎么就会变成243呢?
其实这里有一个本质性的错误,那就是shell获得函数的返回值的方式基本只有两种:
1. 将返回值打印到标准输出或者是文件
2. 将返回值赋值给全局变量
如果这样写:
| #!/bin/sh |
|
| function foo(){ |
|
result=$(echo $1) |
|
echo $result |
| } |
|
| echo `foo 13` |
| echo `foo 1011` |
运行结果就正确了,而且代码废话还少很多。
回到问题上来,那shell里面用return是什么意思呢?其实它只是执行函数执行的状态码,比如执行成功肯定返回0,不成功返回一个1~255之间的数。所以当传入1011时超过了255的范围,被截断为后8位,变成243了。
所以,shell中的return和Java、Python这种语言的return是不一样的,不要想当然,同时shell中的return只能返回数字,如果你试图返回字符串之类运行时就会报错。