Bash Shell 程序结构主要有 : 变量设定 内置命令 Shell 语法结构 函数 其他命令行程序构成
例子:
[root@localhost ~]# vim test.sh #!/bin/bash # #用途:简单的shell程序 # # # function show_name() { echo "今天是 $1 ,你 $2 大大,来自 $3" } name=$1 ip="192.168.1.16" today=$(date +%F) #书中这里写的是 today='date +%F' 可是在执行的时候,总是会打印date +%F字样,百思不得其解,后来在群里问了一下这个脚本的写法,有位朋友告知这种写法,试了一下,成功出来想要的结果。 if [ $# != 1 ]; then echo "Usage: . /$0 [使用者名称]" exit fi show_name "$today" "$name" "$ip" sleep 5 echo echo "Bye-Bye ;-)"
保存脚本。记住,要给脚本加上执行权限才能够执行
chmod +x test.sh
或者
chmod 755 test.sh 还记得什么意思么?不记得了,看上一章节
执行的时候
可以通过
sh test.sh bash test.sh /root/test.sh (绝对路径) 都可以执行该脚本。但这三种方法的特点是,都是在父shell中新开一个子shell环境,在这个子shell环境中来执行脚本程序。
. test.sh 或 source test.sh 这两个命令也可以执行该脚本。这两个命令的特点是在父shell中执行脚本程序
Bash Script 找错
1 通过bash脚本来排错
bash -v test.sh 提示出错行
bash -n test.sh 不执行,仅查看脚本代码
bask -x test.sh 追踪脚本的执行顺序
2 echo
在关键的地方用输出行来做解析。我常用的方式
3 shopt -s -o nounset 命令
书中写的是,bash内置命令 shopt,可以用来设定bash的功能选项。如果启用此选项,可以避免错打变量名称,造成程序执行错误的情况。
做了测试,也没了解个所以然出来。看来又要百度了
原来这个命令是写在脚本里边的,而不是在执行端操作的。
#!/bin/bash shopt -s -o nounset 是放在这里的奥。。。 命令XXXX
Bash Script执行原理
login shell 登录档shell,这个不说了,在以前的博客中写过
/etc/passwd 和/etc/shadow之间的关系
还有一个群组的设置也是同这个一样的设计方式
如果login shell是 /bin/bash则就意味着能够登陆shell。否则就表示不能登录。
父shell和子shell问题。很有意思的一个脚本
#!/bin/bash cd /var/log touch ibeenhere.txt
这个脚本很简单,进入log目录,创建一个文件。有意思的是,第一句话,进入log目录。
如果你用子脚本执行的话,则当前shell是不会进入log目录的。但是确实会创建ibeenhere.txt文件奥。因为子shell进入了该目录,创建了该文件,然后跑了。
但是如果你用父shell执行这个脚本的话,你会发现,他确实进入到了lgo目录中。 什么你忘了怎么用子shell和父shell执行了?没关系,看上面
子shell可以不断进入新的子shell。直接用bash命令就可以进入子的shell层级。查看shell层级的命令 echo $SHLVL ,就可以知道当前是在第几层shell中。
如果要退出当前shell,可以用exit命令来执行。
同样也可以利用 ps axf指令来显示各进程之间的层级关系。
Bash Shell 的启动配置文件
Bash 有5种运行模式,分别是 互动模式 非互动模式 sh名称调用 POSIX模式 限制功能模式