将要执行的命令按顺序保存到一个文本文件;
*
给该文件可执行权限;
*
可结合各种Shell控制语句以完成更复杂的操作。
重复性操作
*
交互性任务
*
批量事务处理
*
服务运行状态监控
*
定时任务执行
shell是一个特殊的应用程序,它介于操作系统内核和用户之间,充当了一个**“命令解释器”**的角色,负责接收用户输入的操作指令并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。
[root@localhost data]#cat /etc/shells
/bin/sh
/bin/bash
/sbin/nologin
/usr/bin/sh
/usr/bin/bash
/usr/sbin/nologin
/bin/tcsh
/bin/csh
因为系统某些服务运行过程中,会去检查用户能够使用的Shell,而这些shell的查询就是借由/etc/shells这个文件。
当用户登录的时候,系统就会给我一个shell让我来用,而这个登录取得的Shell就记录在/etc/passwd这个文件内
脚本申明(解释器) :若第一行为**“!/bin/bash"**,表示此行以下的代码语句是通过/bin/bash程序来解释执行,/#!/bin/bash为默认解释器。还有其它类型的解释器,比如/# !/usr/bin/python. /#! /usr/bin/expect.
.注释信息:以“/#"开头的语句表示为注释信息,被注释的语句在运行脚本时不会被执行。
可执行语句:比如echo命令,用于输出”"之间的字符串
如果想要把文本字符串和命令输出显示在同一行中,可以使用echo语句的 -n
参数。
示例:
[root@localhost ~]#vim first.sh #使用vim编辑器编辑
#!/bin/bash #脚本解释器声明
#this is my first shell-script #注释
echo 当前目录位于: #linux输出命令
pwd #linux命令
#不换行写法
echo -n 当前目录位于:
pwd
#法一:指定路径的命令,要求文件必须有x权限
[root@localhost ~]#chmod +x /root/first.sh
[root@localhost ~]#cd /root/
[root@localhost ~]#./first.sh
当前目录位于:
/root
#法二:指定Shell来解释脚本,不要求文件必须有x权限。
[root@localhost ~]#bash first.sh
当前目录位于:
/root
#法三:source 脚本路径执行shell脚本
[root@localhost ~]#source first.sh
当前目录位于:
/root
区分大小写
不能使程序中的保留字和内置变量:如: if, for, hostname
只能使用数字、字母及下划线,且不能以数字开头,注意:不支持短横线“-",和主机名相反
不要使用内置的变量,使用英文尽量使用词义通俗易懂,PATH
驼峰StudentFirstName
小驼峰studentFirstName·
下划线: student_name
1.命令错误:命令出错不会影响接下来的命令继续2.语法错误
2.语法错误:会影响接下来的命令继续
3.逻辑错误:只能自己去筛查
查找代码的正确:
bash -n 脚本名称 (不在当前目录下加绝对路径) 检查语法错误
bash -x 脚本名称 (不在当前目录下加绝对路径) 检查逻辑错误
由于Shell脚本“批量处理”的特殊性,其大部分操作过程位于后台,不需要用户进行干预,因此要学会提取、过滤执行信息变得十分重要,所以我们需要重定向和管道。
1.管道操作符:“|”: 将管道符号“|"左侧的命令输出的结果,作为右侧命令的输入(处理对象),同一行命令中可以使用多个管道.
[root@localhost ~]#ps aux |wc -l #查看进程数
267
[root@localhost ~]#echo "123123"|passwd --stdin zhangsan #给张三设置密码
1、交互式硬件设备
类型 | 设备文件 | 文件描述编号 | 默认设备 |
---|---|---|---|
标准输入 | /dev/stdin | 0 | 键盘 |
标准输出 | /dev/stdout | 1 | 显示器 |
标准错误输出 | /dev/stderr | 2 | 显示器 |
2、 重定向操作
类型 | 操作符 | 用途 |
---|---|---|
重定向输入 | < | 从指定文件读取数据 |
重定向输出 | > | 将标准输出结果保存到指定的文件,并且覆盖原有文件 |
>> | 将标准输出追加到指定的文件的尾部,不覆盖原有内容 | |
标准错误输出 | 2> | 将错误信息保存到指定文件,并且覆盖原有文件 |
2>> | 将错误信息追加到指定文件的尾部,不覆盖原有内容 | |
混合输出 | &>和2>&1 | 将标准输出,标准错误保存到同—文件中 |
示例1: 将123456重定向输出到pass.txt文件中,然后将pass.txt的内容重定向输入给用户张三的密码,从pass.txt 文件中取密码,需要注意SELinux 会影响此命令执行,若执行失败可尝试关闭SELinux(setenforce 0)。
[root@localhost ~]#useradd lili
[root@localhost ~]#echo "123abc" > pass.txt
[root@localhost ~]#passwd --stdin lili < pass.txt
更改用户 lili 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[root@localhost ~]#
示例2:
#将12345678输入到文件log.txt中
[root@localhost ~]#echo "12345678" > log.txt
[root@localhost ~]#cat log.txt
12345678
[root@localhost ~]#
#再将112234写入log.txt中,这个时候会覆盖原来的数据
[root@localhost ~]#echo "112234" > log.txt
[root@localhost ~]#cat log.txt
112234
[root@localhost ~]#
#继续将112234写入log.txt中,使用>>,这个时候会追加原来的数据
[root@localhost ~]#echo "112234" >> log.txt
[root@localhost ~]#cat log.txt
112234
112234
示例3:
ls -lh > log.txt 2>&1 等同于 ls -lh &> log.txt > (将标准输出结果保存到指定的文件) 2>&1(将标准错误输出重定向到标准输出) &>(将标准输出、标准错误输出保存到同一文件)
用来存放系统和用户需要使用的特定参数(值)
1.
变量名:使用固定的名称,由系统预设或用户定义
1.
变量值:能够根据用户设置、系统环境的变化而变化
**自定义变量:**由用户自己定义、修改和使用;
*
**特殊变量:**环境变量,只读变量,位置变量,预定义变量。
1.定义新的变量:
格式:变量名=变量值
#示例:
[root@localhost ~]#abc=123
2.查看定义的变量的值:
格式echo $变量名
#示例:
[root@localhost ~]#echo $abc
123
3.赋值时使用引号
双引号:允许通过$符号引用其他变量值
*
单引号:禁止引用其他变量值, $视为普通字符
*
反撇号:命令替换,提取命令执行后的输出结果,``和$(…)作用相同
4.从键盘输入内容为变量赋值
#法一: read命令获取输入内容
##格式
read -p 提示信息 变量名
echo $变量名
###示例:
[root@localhost ~]#resault=`echo ${abc}3.3`
[root@localhost ~]#echo $resault
1233.3
[root@localhost ~]#read -p "请输入你的名字:" name
请输入你的名字:yxp
[root@localhost ~]#
#法二:在脚本中编写,在命令行实现read获取
##示例:
[root@localhost ~]#vim name.sh
#!/bin/bash
read -p “请输入你的名字” name
echo "--------"
read -p “请输入他的名字” name1
echo "--------"
echo "你的名字是"
echo $GAME
echo "他的名字是"
echo $GAME2
法一:
法二:
默认情况下,新定义的变量只在当前的Shell环境中有效,因此称为局部变量。当进入子程序或新的子Shell环境时局部变量将无法再使用。
*
可以通过内部命令export将指定的变量导出为全局变量,使用户定义的变量在所有的子Shell环境中能够继续使用。
变量名设置格式:变量名=变量值
全局变量格式:export 变量名=变量值
示例1:临时设置变量
示例2:永久设置变量,需要在/etc/profile文件里面添加
vim /etc/profile
export PATH+=:/mnt
[root@localhost data]#source /etc/profile
[root@localhost data]#echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/data:/mnt
运算符:+ 加法
、- 减法
、/乘法
、/除法
、% 取余
*
常见表达式:
expr 变量1 运算符 变量2
var=$(expr 变量1 运算符 变量2)
var=$((变量1 运算符 变量2))
var=$[变量1 运算符 变量2]
let var=变量1 运算符 变量2
i++相当于i=$[$i + 1],i++是先赋值,再运算
i--相当于i=$[$i - 1],++i是先运算再赋值
i+=1相当于i=$[$i + 1]
**示例1:**使用管道符
[root@localhost data]#echo 1 + 2|bc
3
**示例2:**expr不可计算小数,并且变量和运算符之间需要空格分隔
[root@localhost data]#expr 1 + 2
3
**示例3:**计算乘法时,需要使用“\”转义符
[root@localhost data]#expr 1 \* 2
2
**示例4:**取余只需要除后的余数
#法一
[root@localhost data]#expr 3 % 2
1
#法二:定义变量,使用反撇号
[root@localhost data]#shu=`expr 3 % 3`
[root@localhost data]#echo $shu
0
**示例5:**随机取余
[root@localhost data]#expr $RANDOM % 33
6
[root@localhost data]#expr $[RANDOM % 10 + 1]
7
[root@localhost data]#echo $[RANDOM % 10 + 1]
10
**示例5:**使用let
[root@localhost data]#a=2
[root@localhost data]#b=3
[root@localhost data]#z=0;let z=a+b;echo $z
5
**示例6:**i和i
[root@localhost data]#i=1;j=1;let j=i++;echo $i $j
2 1
[root@localhost data]#i=1;j=1;let j=++i;echo $i $j
2 2
使用 env 命令可以查看到当前工作环境下的环境变量
*
变量USER表示用户名称,HOME表示用户的宿主目录,LANG表示语言和字符集,PWD表示当前所在的工作目录,变量PATH表示可执行程序的默认搜索路径
*
配置文件:/etc/profile(全局生效)、~/.bash_profile(当前用户环境)
示例:将文件所在目录添加路径,可以执行脚本
[root@localhost data]#echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/data
[root@localhost data]#chmod +x 1.txt
[root@localhost data]#1.txt
hello,shell!
readonly
命令用于定义只读shell变量和shell函数。readonly
命令的选项-p
可以输出显示系统中所有定义的只读变量。
格式:readonly 【选项】【参数】
[root@localhost data]#readonly abc=111
[root@localhost data]#abc=222
bash: abc: 只读变量 #再想修改只读变量就无法修改了
当执行命令行操作时,第一个字段表示命令名或脚本程序名,其余的字符串参数按照从左到右的顺序依次赋值给位置变量。
*
$n:n为数字,$0代表命令本身,1~9代表第一个到第九个参数,十以上的参数需要使用大括号表示,比如第十个参数为 ${10}
示例1:
示例2:
$/* 和 $@:都会表示命令或脚本要处理的参数。
$/* :把所有参数看成以空格分隔的一个字符串整体(单字符串)返回,代表"$1 $2 $3 $4 "
*
$@:把各个参数加上双引号分隔成n份的参数列表,每个参数作为一个字符串返回,代表“$1” “$2” “$3” “$4”
预定义变量 | 表示的意思 |
---|---|
$/* | 把所有参数看成以空格分隔的一个字符串整体(单字符串)返回,代表"$1 $2 $3 $4 " |
$@ | 把各个参数加上双引号分隔成n份的参数列表,每个参数作为一个字符串返回,代表“$1” “$2” “$3” “$4” |
$0 | 表示当前执行的脚本或命令的名称 |
$/# | 表示命令或者脚本要处理的参数的个数 |
$? | 表示前一条命令或脚本执行后的返回状态码,返回值为0表示执行正确,返回任何非0值均表示执行出现异常,也常被用于shell脚本中return退出函数并返回的退储值 |
[root@localhost data]#ip=`ifconfig ens33|awk /netmask/'{print $2}'`
[root@localhost data]#echo $ip
192.168.59.102
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/m0_51160032/article/details/120847872
内容来源于网络,如有侵权,请联系作者删除!