"Shell编程脚本"
运用方式:
- 编写shell进行服务器的维护
- 编写shell脚本管理集群
shell概念
- 是一个命令解释器,它为用户提供一个向linux内核发送以便运行程序的界面系统级程序,用户可以用shell来启动,挂起,停止或者编写一些程序。
Shell脚本的执行方式
脚本格式要求
- 脚本要以 #!/bin/bash开头
- 脚本要有可执行权限
编写一个shell程序并输出hello world!
#!/bin/bash
echo "hello world!"
执行方式
- 赋予x权限 chmod u+x 文件名 ./文件名
- 直接执行 sh 文件名(这个方法不用赋予权限也可以直接执行)
shell变量
- 分为系统变量和用户自定义变量
- 系统变量: H O M E 、 HOME、 HOME、PWD、 S H E L L 、 SHELL、 SHELL、USER等等
- 显示当前shell中所有变量:set
定义shell变量
- 基本语法
- 定义变量:变量名=值(中间不能有空格)
- 撤销变量:unset 变量
- 声明静态变量:readonly 变量名=值
- 特别声明:readonly变量不能unset(即不能撤销)
快速入门
#!/bin/bash
#案例1:定义变量A
A=1
#案例2:撤销变量A
unset A
#案例3:声明静态的变量B=2,不能unset
readonly B=2
输出变量要加‘$’符号
#!/bin/bash
#定义变量A 并输出他的值
A=1
echo $A
echo "$A"
将指令结果赋给变量
#!/bin/bash
#若要将data日期指令赋给变量 变量CD各代表一种写法
#(`为反单引号)
C=`data`
D=$(data)
#输出变量要加"$"符号
echo "$C"
echo "$D"
多行注释/单行注释
- 单行注释:符号#
- 多行注释:符号 :<<! 。。。。。内容。。。。。。。!
设置环境变量
基本语法
- export 变量名=变量值(将shell变量输出为全局变量/环境变量)
- source 变量值(让修改后的配置信息生效)
- echo $变量名(查询环境变量的值)
#!/bin/bash
#1) 在/etc/profile 文件中定义 TOMCAT_HOME环境变量
export TOMCAT_HOME=/ect/profile
#让定义生效
source /ect/profile
#2) 查看环境变量TOMCAT_HOME的值
echo $TOMCAT_HOME
:<<!
3) 在另外一个shell程序中使用 TOMCAT_HOME
vim 进入另一个程序
然后 echo $TOMCAT_HOME
!
位置参数变量
位置参数概念:
- 当我们执行一个shell脚本时候,希望获得命令行参数信息,就可以使用位置参数变量
- 在调用函数或方法时,按照特定顺序传递的参数。
- 这些参数在函数定义时不需要指定名称,它们按照在函数调用中出现的顺序被赋值给函数内部的变量。
基本语法:
- $ n (功能描述:n为数字,$0代表命令本身,$1-$9代表第一到第九个参数,十以上的参数,十以上的参数需要用
- $ *(功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
- $ @(功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
- $ #(功能描述:这个变量代表命令行中所有参数的个数
预定义变量(了解即可)
基本概念
- 预定义变量(Process Identifier,通常缩写为PID)是一个用于唯一标识一个进程的数字。在类Unix操作系统(如Linux和macOS)和Windows操作系统中,每个正在运行的进程都会被分配一个唯一的进程号。
- 进程号对于系统管理员和用户来说都非常重要,因为它们是管理和监控系统中进程活动的基础。通过PID,用户可以控制(如启动、停止、杀死)特定的进程,也可以分析进程的资源使用情况和行为。
扩展进程号特点
唯一性:在任何给定时间,一个PID只分配给一个进程。一旦一个进程结束,它的PID可能会被操作系统回收并分配给将来创建的进程。
动态分配:进程号通常是动态分配的,这意味着它们不是预先分配的,而是在进程创建时由操作系统分配。
内核管理:操作系统的内核负责管理所有进程的PID,包括分配新的PID,跟踪当前的PID,以及在进程结束时释放PID。
查找进程:PID可以用来在系统上查找和识别特定的进程。例如,在Linux上,你可以使用ps命令来查看所有正在运行的进程及其PID。
特权级别:在某些系统中,PID的范围可能会根据进程的特权级别而有所不同。例如,在Linux上,通常用户空间进程的PID范围是1到32767,而内核进程的PID范围是32768以上。
PID 1:在Unix系统中,PID 1通常被分配给init进程,它是系统中的第一个用户级进程,负责启动其他所有用户级进程。
工具使用:可以使用多种工具和命令来操作或查看进程的PID,如ps, top, htop, kill等。
跨平台差异:不同操作系统的PID实现可能略有不同,但基本概念是相同的。
基本语法:
- $$ 表示当前进程的进程号PID
- $! 表示后台运行最后一个进程的进程号(PID)
- $? 表示最后一次执行的命令的返回状态。如果变量值为0,证明上一个命令执行正确;如果非0,就执行不正确
运算符
基本介绍
- 如何在shell脚本中进行各种运算操作
基本语法
- $((运算式))
- $[运算式] ---------------------最推荐
- expr m+n
注意
- expr运算符之间要有空格,如果希望将expr的结果赋给某个变量,要用反引号(`)(在键盘Esc的下面那个键)
- 同时expr的符号有自己的特点: * , / , % 乘 除 取余
快速入门栗子:
计算(2+30)*4的值(注意赋值符号之间不能有空格)
计算命令行两个参数的和 A+B
#!/bin/bash
#计算(2+30)*4的值
A=$((2+30)*4))
B=$[(2+30)*4]
C=`expr (2+3)\*4
echo $A $B $C
#使用位置参数
sum=$[$1+$2]
echo $sum
条件判断
基本语句
[ ] -----条件布尔语句
- [ ]括号中写内容 注意内容和括号两边都要打一个空格 语法硬性要求
- 若括号内为非空(有内容)返回true 否则返回false
举个栗子
[ 啊强 ] 返回true(不要忘记括号两边的空格)
[ ] 返回false
条件判断语句
- = 字符串比较
两个整数的比较 - -lt小于
- -le小于等于little equal
- -eq等于
- -gt大于
- -ge大于等于
- -ne不等
按照文件权限进行判断 - -r 有读的权限
- -w 有写的权限
- -x 有执行的权限
按照文件类型进行判断 - -f 文件存在并且是一个常规的文件
- -e 文件存在
- -d 文件存在并是一个目录
案例
#!/bin/bash
#判断“ok”等于“ok”
if [ "ok" = "ok" ]then
echo "equal"
fi
#判断23是否大于等于22
if [ 23 -ge 22 ]then
echo "大于等于它"
fi
#判断/root/test目录中文件是否存在
if [ -f /root/test ]then
echo "存在"
fi
判断是否输出空
if []then
echo "kon"
fi
#答案不输出 因为false 同时也要注意尽管方括号内无内容也要加个空格 不然报错
流程控制
if条件判断
#!/bin/bash
if [ 条件 ]
then
代码
fi
多分支if条件
#!/bin/bash
if [ 条件 ]
then
代码
elif [ 条件 ]
then
代码
else
then
代码
fi
case语句
#!/bin/bash
case $变量命名 in
"值1")
程序
#如果变量值为值1就执行此程序
;;
"值2")
程序
;;
*)
程序
#如果不是值1值2 就执行这里的程序
esac
for循环
语法1
#!/bin/bash
for i in "$*"
do
echo "i"
done
#命名行 sh test.sh 1 2 3
#输出为 1 2 3
for i in "$@"
do
echo "i"
done
#命令行 sh test.sh 1 2 3
#输出为
#1
#2
#3
#因此区别在于$*把变量看为一个整体 $@ 把变量看为个体
语法2
for(( 初始值;控制条件;变量变化 ))
do
代码
done
例题:输出1-100合的值 变量为sum
#!/bin/bash
for(( i=1; i<=100; i++ ))
sum=0
do
sum=$[$sum+$i]
done
echo "$sum"
while循环
#!/bin/bash
while [ 条件 ]
do
代码
done
- 注意:
- while 与 【】之间有空格
- 条件与【】之间也有空格
read读取控制台输入
基本语法
- read(选项)(参数)
- 选项:
-p: 指定读取值时候的提示符
-t:指定读取值时候的等待时间(秒),如果没有指定的时间输入,就不再等待。。。 - 参数
变量:指定读取的变量名
实例
#!/bin/bash
#读取控制台输出的一个num1
read -p "输入num1"num1
echo "num1的值为$num1"
#读取控制台输入的一个num2值,并在10s内输入
read -t 10 -p "输入num2"num2
echo "num2值为$num2"
系统函数
- 概念: 顾名思义就是系内部定义定义好的函数 直接调用即可
basename函数
- 概念:用来返回路径的最后部分 也就是文件名
- 语法:basename[pathname][suffix]
- suffix为后缀,如果suffix被指定了,basename会将pathname或string中的suffix去掉
案例:/home/aaa/test.sh
basename /home/aaa/test.sh
输出结果为 test.sh
basename /home/aaa/test.sh .sh
输出结果为 test
dirname函数
- 概念:用来返回完整路径除文件名的部分
案例:/home/aaa/test.sh
dirname /home/aaa/test.sh
输出结果为:/home/aaa
自定义函数
- 语法
#定义函数
function 函数名(){
属性和方法
}
#输入值(read指令)
read -p "请输入一个数n1="n1
#调用函数
函数名 $值
*案例:构造一个两数之和的函数getSum
#!/bin/bash
function getSum(){
Sum=&[&n1+&n2]
echo "和为&Sum"
#输入两个值
read -p "输入一个数n1="n1
read -p "输入一个数n2="n2
#调用函数
getSum $n1 $n2