shell编程 变量

tech2022-07-06  209

变量

shell变量的类型自定义变量环境变量位置变量和预定义变量 变量的运算整数运算小数运算

shell

壳 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.sh

3.观察目录改变了。说明影响的是当前。并使用子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:保留小数点后面两位

最新回复(0)