壳 Shell语言的特点 SHELL语言是指UNIX操作系统的命令语言,同时又是该命令语言的解释程序的简称。 Shell本身是一个用C语言编写的程序,它是用户使用Unix/Linux的桥梁,用户的大部分工作都是通过Shell完成的。 Shell既是一种命令语言,又是一种程序设计语言。作为命令语言,它交互式地解释和执行用户输入的命令; 作为程序设计语言,它定义了各种变量和参数,并提供了许多在高级语言中才具有的控制结构,包括循环和分支。 它虽然不是Unix/Linux系统内核的一部分,但它调用了系统核心的大部分功能来执行程序、 建立文件并以并行的方式协调各个程序的运行。 因此,对于用户来说,shell是最重要的实用程序, 深入了解和熟练掌握shell的特性极其使用方法,是用好Unix/Linux系统的关键。 Shell 能做什么?
自动化批量系统初始化程序 (update,软件安装,时区设置,安全策略…)自动化批量软件部署程序 (LAMP,LNMP,Tomcat,LVS,Nginx)应用管理程序 (KVM,集群管理扩容,MySQL,DELLR720批量RAID)日志分析处理程序(PV, UV, 200代码, !200代码, top 100, grep/awk)自动化备份恢复程序(MySQL完全备份/增量 + Crond)自动化管理程序(批量远程修改密码,软件升级,配置更新)自动化信息采集及监控程序(收集系统/应用状态信息,CPU,Mem,Disk,Net,TCP Status,Apache,MySQL)配合Zabbix信息采集(收集系统/应用状态信息,CPU,Mem,Disk,Net,TCP Status,Apache,MySQL)自动化扩容(增加云主机——>业务上线) zabbix监控CPU 80%+|-50% Python API AWS/EC2(增加/删除云主机) + Shell Script(业务上线)俄罗斯方块,打印三角形,打印圣诞树,打印五角星,运行小火车,坦克大战,排序算法实现Shell可以做任何事(一切取决于业务需求) shell执行方式 多种执行方式 [root@localhost tmp]#vim file1 echo "hello 2020" read -p "请输入您的姓名:" name echo "哈哈 $name 是大笨蛋"执行1:bash ping01.sh 执行2:sh ping01.sh 执行3:. bash.sh 执行4: source bash.sh 多种执行方式的区别 1和2的方式,是子shell 3和4的方式,是本shell
1.准备环境
vim bash.sh #!/usr/bin/bash cd /home/ ls
一种执行方式测试 . bash.sh3.观察目录改变了。说明影响的是当前。并使用子shell执行方式执行。 该种执行方式,是不同于前者SUB shell执行。 而是在当前shell执行,用于影响当前shell环境。 Shell解释器有哪些 shell 命令就是前一阶段所学习的大部分命令。 cp ls date组合到一起。
Linux支持的shell有哪些呢? cat /etc/shells 或 chsh –l
自定义变量(示例:ping01.sh引入变量)
定义变量: 变量名=变量值 变量名必须以字母或下划线开头,区分大小写 ip1=192.168.2.115
Read -p “打印内容” 变量名
引用变量: $变量名 或 ${变量名} 查看变量: echo $变量名; "set"可以查看所有变量(包括自定义变量和环境变量) 取消变量: unset 变量名 作用范围: 仅在当前shell中有效 示例: 使用变量前。麻烦
ping -c1 192.168.100.10 &>/dev/null && echo 192.168.100.10up || echo 192.168.100.10down使用变量后,简洁
#!/bin/bash ip=192.168.100.10 ping -c1 $ip &>/dev/null && echo $ip up || echo "$ip down"变量赋值(定义变量)
显式赋值 变量名=变量值 示例: ip1=192.168.1.251 school="BeiJing 1000phone" today1=`date +%F` today2=$(date +%F) read 从键盘读入变量值 read 变量名 read -p "提示信息: " 变量名 read -t 5 -p "提示信息: " 变量名 //-t 等待5秒,后超时 read -n 2 变量名 //-n 只记录几个字符 read -p "请输入您测试的IP地址:" ip ping -c1 $ip &>/dev/null && echo " $ip up" || echo "$ip down" ~注意事项:3种引号 " " 弱引用 ’ ’ 强引用
[root@tianyun ~]# school=1000phone [root@tianyun ~]# echo "${school} is good" //脱去空格
1000phone is good [root@tianyun ~]# echo '${school} is good'//脱去所有字符 ${school} is good 优先执行 命令替换 等价于 $() 反引号中的shell命令会被先执行
[root@tianyun ~]# touch `date +%F`_file1.txt [root@tianyun ~]# touch $(date +%F)_file2.txt错误
[root@tianyun ~]# disk_free3="df -Ph |grep '/$' |awk '{print $4}'"正确
[root@tianyun ~]# disk_free4=$(df -Ph |grep '/$' |awk '{print $4}') [root@tianyun ~]# disk_free5=`df -Ph |grep '/$' |awk '{print $4}'`定义环境变量: 方法一 export back_dir2=/home/backup 方法二 export back_dir1 将自定义变量转换成环境变量 引用环境变量: $变量名 或 ${变量名} 查看环境变量: echo $变量名 env 例如env |grep back_dir2 取消环境变量: unset 变量名 变量作用范围: 在当前shell和子shell有效 !!! 使变量开机、登陆生效,将变量放到~/.bash_profile
语法 命令 参数1 参数2 参数3 …9以后特殊定义
$1 $2 $3 $4 $5 $6 $7 $8 $9 ${10} … 预先定义过的变量 $0 脚本名 $* 所有的参数 $@ 所有的参数 $# 参数的个数 $$ 当前进程的PID $! 上一个后台进程的PID $? 上一个命令的返回值 0表示成功
示例1: #vim test.sh #!/usr/bin/bash echo “第2个位置参数是$2” echo “第1个位置参数是$1” echo “第4个位置参数是$4”
echo “所有参数是: $*” echo “所有参数是: $@” echo “参数的个数是: $#” echo “当前进程的PID是: $$”
echo ‘$1=’$1 echo ‘$2=’$2 echo ‘$3=’ 3 e c h o ′ 3 echo ' 3echo′*=’ ∗ e c h o ′ * echo ' ∗echo′@=’ @ e c h o ′ @ echo ' @echo′#=’KaTeX parse error: Expected 'EOF', got '#' at position 1: #̲ echo ' = ′ =' =′$ [root@localhost ~]# chmod +x 1.sh
[root@localhost ~]# ./1.sh 1 2 3 4 5 6 7 8 9 第2个位置参数是2 第1个位置参数是1 第4个位置参数是4 所有参数是: 1 2 3 4 5 6 7 8 9 所有参数是: 1 2 3 4 5 6 7 8 9 参数的个数是: 9 当前进程的PID是: 1946 $1=1 $2=2 $3=3 $*=1 2 3 4 5 6 7 8 9 $@=1 2 3 4 5 6 7 8 9 $#=9 $$=1946 ∗ 与 *与 ∗与@区别关于$* 和 $@的 一点 认识 同是菜鸟一起学习
∗ 所 有 的 位 置 参 数 , 被 作 为 一 个 单 词 . 注 意 : " * 所有的位置参数,被作为一个单词. 注意:" ∗所有的位置参数,被作为一个单词.注意:"*“必须被”“引用. @ 与 @ 与 @与*同义,但是每个参数都是一个独立的”“引用字串,这就意味着参数被完整地传递, 并没有被解释和扩展.这也意味着,每个参数列表中的每个参数都被当成一个独立的 单词. 注意:”$@"必须被引用.
$@ $* 只在被双引号包起来的时候才会有差异 双引号括起来的情况: $*将所有的参数认为是一个字段 $@以IFS(默认为空格)来划分字段,如果空格在“”里面,不划分。采用LS的脚本运行./test 1 “2 3” 4 来发现差异
没有括起来的情况是 @ 和 @和 @和*一样的,见到IFS就划分字段。还是采用LS的脚本运行./test 1 “2 3” 4 来发现差异
一个小例子 ,仅供参考
[Copy to clipboard] [ - ]CODE:#!/bin/bash echo
index=1
echo “Listing args with”$":" for arg in "$"
do echo “Arg # i n d e x = index= index=arg” let “index+=1”
done
echo “所有的参数被认为是一个单词”
echo
index=1
echo “Listing args with “$@”:” for arg in “KaTeX parse error: Expected 'EOF', got '#' at position 17: …" do echo "Arg #̲index=$arg” let “index+=1” done
echo “所有的参数被认为是各个独立的单词”
echo
index=1
Expr 语法:expr 1 + 2 + - * / % 加 减 乘 除 取余 *是任意字符,使用\转义一下 $(()) Echo $((1+2)) Echo $((2**3)) 2的三次方 $[] Echo $[1+2] Let Let sum=1+2 ; echo $sum
Echo “scale=2;6/4” | bc Bc:交互运算器 Scale=2:保留小数点后面两位