ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

Shell编程与变量

2022-01-19 23:58:37  阅读:95  来源: 互联网

标签:Shell 变量 编程 echo shell bash root localhost


Shell编程与变量

一,概述

1.概念

1)什么是shell:

shell是一个命令解释器,它在操作系统的最外层,负责直接与用户进行对话,把用户的输入解释给操作系统,并处理各种各样的操作系统的输出结果,输出到屏幕反馈给用户。这种对话方式可是交互也可以是非交互式的,我们所输入的命令计算机是不识别的,这时就需要一种程序来帮助我们进行翻译,变成计算机能识别的二进制程序,同时又把计算机生成的结果返回给我们。
  • 将要执行的命令按照顺序保存到一个文本文件
  • 给该文件可执行权限
  • 结合各种shell控制语句以完成更复杂的操作

2)shell脚本是什么:

shel1脚本就是说我们把原来linux命令或语句放在一个文件中,然后通过这个程序文件去执行时,我们就说这个程序为 shell脚本或shell

程序;我们可以在脚本中输入一系统的命令以及相关的语法语句组合,比如变量,
流程控制语句等,把他们有机结合起来就形成了一个功能强大的shell 脚本

总结:将需要执行的命令保存到一个文件中,按照顺序执行,它不需要编译,它是解释型的

3 ) shell脚本能干什么

  • 自动化完成软件的安装部署,如安装部署LAMP架构服务
  • 自动化完成系统的管理,如批量添加用户
  • 自动化完成备份,如数据库定时备份
  • 自动化的分析处理,如网站访问量

4 ) shel1脚本使用场景

在需要完成大量复杂、重复性的工作时,不需要在命令行重复执行命令,直接运行shell脚本即可,大大的节省了时间提高了效率

2.shell作用—命令解释器,“翻译官”

Linux系统中的shell是一个特殊的应用程序,介于操作系统内核与用户之间
Linux系统中的shell是一个特殊的应用程序,它介于操作系统内核与用户之间,充当了一个"命令解释器"的角色,负责接收用户输入的操作指令(命令)并进行解释,将需要执行的操作传递给内核执行,并输出执行结果。

解释器:能够执行用其他计算机语言编写的程序的系统软件

常见的shell 解释器程序有很多种,使用不同的shell时,其内部指令、命令行提示符等方面会存在一些区别。通过/etc/shells文件可以了解当前系统所支持的shell 脚本种类。

[root@localhost ~]# cat /etc/shells
/bin/sh#是bash命令的软链接(已经被/bin/bash所替换)/bin/bash基准于GNU的框架下发展出的shell。
/usr/bin/sh己经被bash所替换。
/usr/bin/bash #centos和redhat系统默认使用bash shell
/bin/tcsh #csh的增强版,与csh完全兼容整合了csh,提供更多的功能。/bin/csh已经被/bin/bash所替换(整合c shell,提供更多的功能)

注: nologin:奇怪的shell,这个shell可以让用户无法登录主机。
bash ( /bin/bash)是目前大多数Linux版本采用的默认shell。
1)为什么我们的系统上合法的shell要写入/etc/shells这个文件?
这是因为系统某些服务在运行过程中,会去检查用户能够使用的shells,而这些shell的查询就是借由/etc/ shells这个文件。

2)用户什么时候可以取得shell来工作?还有我这个默认会取得哪一个shell?
当我登录的时候,系统就会给我shell让我来工作,而这个登录取得的shell就记录在/etc/passwd这个文件内。
不同的shell具备不同的功能,shell还决定了Linux中默认的shell是/bin/bash,流行的shell有ash、bash、ksh、csh、zsh等,不同的shell都有自己的特点以及用途
目前大多数linux系统默认使用的是bash

shell,默认登陆shell是/bin/bash,可以查看/etc/passwd文件里注明
这个shell是针对用户而言的,可以查看/etc/passwd里面的最后的字段使用的是哪个shell,如果想要修改可以用chmod -s或者chsh -s来重新指定

3.脚本构成

第一行为"#!/bin/bash" ,脚本申明(默认解释器)∶表示此行以下的代码语句是通过/bin/bash程序来执行。还有其他类型的解释器,

比如#! /usr/bin/python、#!/usr/bin/expect

注释信息:以"#"开头的语句表示为注释信息,被注释的语句在脚本运行时不会被执行可执行语句:如echo命令,用于输出""之间的字符串

例:
vim first.shcd /boot/pwd
ls -lh vml*

例:
#!/bin/bash
#This is my first shell-script.cd /boot
echo "当前的目录位于:"pwd
echo "其中以vml开头的文件包括:"ls -lh vml*

4.shell编程规范

1.创建步骤:

1.创建一个包含命令和控制结构的文件
2.修改这个文件的权限使它可以执行,chmod +x xxxx.sh
3.检测语法错误
4.执行  ./xxxx.sh

2.执行脚本的方式:

方法一:
当前路径(绝对路径与相对路径)下执行脚本(要有执行权限)
/home/first.sh或者./first.sh

方法二:
sh . bash脚本文件路劲(这种方式可以不对脚本文件添加执行权限)
bash first.sh或sh first.sh

方法三: 
source脚本文件路劲(可以没有执行权限)source first.sh

方法四:其他方法
sh < first.sh或者cat first.sh |sh (bash)

5.重定向与管道

1)交互式硬件设备

  • 标准输入:从该设备接收用户输入的数据
  • 标准输出:通过该设备向用户输出数据
  • 标准错误:通过该设备报告执行出错信息
类型          设备文件     文件描述编号    默认设备
标准输入      /dev/stdin    0             键盘
标准输出      /dev/stdout   1             显示器
标准错误输出  /dev/stderr   2             显示器
重定向操作:
类型	      操作符	 用途
重定向输入	 <	     从指定的文件读取数据
重定向输出	 >	     将标准输出结果 保存 到指定的文件,并且覆盖原有内容
重定向输出	 >>	     将标准输出结果 追加 到指定的文件的尾部,不覆盖原有内容
标准错误输出	2>	    将错误信息 保存 到指定的文件,并且覆盖原有内容
标准错误输出	2>>	    将错误信息 追加 到指定的文件的尾部,不覆盖原有内容
混合输出	 &>	     将标准输出、标准错误保存到同一文件中
混合输出	 2>&1	 将标准错误输出重定向到标准输出

2)重定向输出

重定向输出指的是将命令的正常输出结果保存到指定的文件中,而不是直接显示在显示器的屏幕上。
重定向输出使用">“或”>>"操作符号,分别用于覆盖或追加文件
若重定向输出的目标文件不存在,则会新建该文件,然后将前面命令的输出结果保存到该文件中﹔若目标文件已经存在,则将输出结果覆盖或追加到文件中。

>:意思是当原来文件中有内容的话,原来的内容会被覆盖掉

>>:意思是当原来文件中有内容的话,新加的内容会追加到里面而不会覆盖原来的内容
例如:
uname -p > kernel.txt

[root@localhost ~]# cat l.txt//以键盘为输入设备,这也是系统默认的1234

[root@localhost ~]# cat <1.txt
1234
//跟cat 1.txt结果是一样的,但是这是以1.txt文件作为输入设备了

默认情况下,cat命令会接受标准输入设备(键盘)的输入,并显示到控制台,但如果用文件代替键盘作为输入设备,那么该命令会以指定的文件作为输入设备,并将文件中的内容读取并显示到控制台

[root@localhost ~] # cat <<0
//以o作为分界符,只要不输入o就会一直输入数据从而显示到屏幕
>123
>456
>0
123
456
[root@localhost ~]# cat << 0 > a.txt
//可以把输入重定向和输出重定向结合使用,把从屏幕输出的内容保存到文件>123
>456
>0
[root@localhost ~]# cat a.txt
123
456


cat << o gtyguyuhuih 0

例1:将错误显示的内容和正确显示的内容分开
ls /etc/passwd  XXXX
ls:无法访问xxx:没有那个文件或目录
/etc/passwd

ls letc/passwd xxx > a.txtl
ls:无法访问xxx:没有那个文件或目录
cat a.txt
/etc/passwd

ls /etc/passwd xxx 2> a.txt
/etc/passwd
cat a.txt
ls:无法访问xxx:没有那个文件或目录
注:使用2>操作符时,会像使用>一样覆盖目标文件的内容,若追加而不覆盖文件的内容即可使用2>>操作符

列:
tar jcf /nonedir/etc.tgz /etc/ 2> error.log
cat /error.log

例:
在编译源码包的自动化脚本中,若要忽略make、make install等操作过程信息,则可以将其定向到空文件/dev/null。

# !/bin/bash 
#自动编译安装httpd 服务器的脚本
cd /usr/src/httpd-2.4.25/
./configure --prefix=/usr/local/httpd --enable-so &> /dev/nullmake &> /dev/null
make install &> /dev/null 
#/dev/null等同于make install > /dev/null 2>&

错误重定向:
错误重定向指的是将执行命令过程中出现的错误信息(如选项或参数错误等)保存到指定的文件,而不是直接显示在屏幕上。错误重定向使用"2>"操作符

2个作用:
在实际应用中,错误重定向可用来收集程序执行的错误信息,为排错提供依据
还可以将无关紧要的错误信息重定向到空文件/dev/null 中,以保持脚本输出的简洁

使用"2>“操作符时,会像使用”>"操作符一样覆盖目标文件的内容,若要追加内容而不是覆盖文件,则应改用"2>>"操作符

当命令输出的结果可能既包括标准输出(正常执行)信息,又包括错误输出信息时,可以使用操作符">""2>“将两类输出信息分别保存到不同的文件,也可以使用”&>"操作符将两类输出信息保存到同一个文件

3)管道操作

管道(pipe)操作为不同命令之间的协同工作提供了一种机制,位于管道符号"|"左侧的命令输出的结果,将作为右侧命令的输入(处理对象),同一行命令中可以使用多个管道。
在 shell脚本应用中,管道操作通常用来过滤所需要的关键信息。
$bash $表示系统提示符,$表示此用户为普通用户,超级用户的提示符是#,bash是shell的一种,是linux下最常用的一种shell
$bash的意思是执行一个子shell,此子shell为bash.
例:
rpm -qa | grep httpd
grep "/bin/bash$" /etc/passwd | awk -F: '{print $1,$7 }'
列:
df -hT | grep "/$" | awk '{print $6}’I
总结:
重定向与管道操作是shell环境中十分常用的功能,若能够熟练掌握并灵活运用,将有助于编写代码简洁但功能强大的shell 脚本程序

二,shell变量

Shell变量的作用、类型

变量的作用
●用来存放系统和用户需要使用的特定参数(值)
变量名:使用固定的名称,由系统预设或用户定义
变量值:能够根据用户设置、系统环境的变化而变化

变量的类型
●自定义变量:由用户自己定义、修改和使用
●特殊变量:环境变量,只读变量,位置变量,预定义变量

1.自定义变量

变量的定义:

Bash中的变量操作相对比较简单,不像其他高级编程语言(如c/c+、Java等)那么复杂。在定义一个新的变量时,一般不需要提前进行声明,而是直接指定变量名称并赋给初始值(内容)即可

格式:变量名=变量值
变量名:临时存放数据的地方
变量值:临时的可变化的数据

永久环境变量存在于~/.bashrc文件中(掉电或者重启后,不会消失), 在每个shell启动的时候, 都会将永久环境变量导入到shell中, 并成为shell的临时环境变量, 这个临时的环境变量可以被unset掉后, 但不会影响其他shell, 因为我们即将会说到, 不同shell的临时环境变量是彼此独立的。

等号两边没有空格。变量名称需以字母或下划线开头,名称中不要包含特殊字符(如+、一、*、/、 .、 ?、%、&、#等)
用echo查看和引用变量的值
通过在变量名称前添加前导符号"$”,可以引用一个变量的值,使用echo命令可以查看变量,可以在一条echo命令中同时查看多个变量值
例:
Product=Python
version=2.7.13
echo $Product$version
当变量名称容易和紧跟其后的其他字符相混淆时,需要添加大括号"{}"将其括起来,否则将无法确定正确的变量名称。对于未定义的变量,将显示为空值
例:
echo ${Product}2.5
echo $ {test }RMB
echo选项
echo -n表示不换行输出
使用echo -e输出转义字符,将转义后的内容输出到屏幕上

常用的转义字符如下:
\c:不换行输出,在"\c"后面不存在字符的情况下,作用相当于echo -n
\换行
\t:转义后表示插入tab,即制表符
注:\转义符,跟在\之后的特殊符号将失去特殊含义,变为普通字符。
如\s将输出"s"符号,而不当做是变量引用
例:
[ root@localhost ~]#echo -n hello
hello [root@localhost ~]#

取消定义
unset变量名

特殊操作
还有一些特殊的赋值操作,可以更灵活地为变量赋值,以便适用于各种复杂的管理任务
双引号("")
双引号主要起界定字符串的作用,特别是当要赋值的内容中包含空格时,必须以双引号括起来;其他情况下双引号通常可以省略
1、当内容中有空格
echo "hello world"
echo nihao
2、当以变量的值进行赋值
[root@localhost ~]. version=2
[root@localhost ~]# pyver="python $version"
[root@localhost ~]# echo $pyver
python 2

单引号('')
当要赋值的内容中包含$、"、\等具有特殊含义的字符时,应使用单引号括起来。
在单引号的范围内,将无法引用其他变量的值,任何字符均作为普通字符看待。输入什么就显示什么但赋值内容中包含单引号(')时,需使用\'符号进行转义,以免冲突。
[root@localhost ~]# test=123
[root@localhost ~]# echo "$test"
123
[root@localhost ~]# echo '$test'
$test

反撇号(``)
反撤号主要用于命令替换,允许将执行某个命令的屏幕输出结果赋值给变量。反撇号括起来的范围内必须是能够执行的命令行,否则将会出错
ls -lh 'which useradd`
先通过 which useradd命令查找出 useradd命令的程序位置,然后根据查找结果列出文件属性
date +号Y-%m-%d
[root@localhost ~]# time= `date +%T`
[root@localhost ~]# echo $time
04:23:22

使用反撇号难以在一行命令中实现嵌套命令替换操作,这时可以改用"$()”来代替反撇号操作,以解决嵌套的问题
rpm -qc $(rpm -qf $(which useradd))

2.输入内容为变量赋值

交互式定义变量

read命令
使用 Bash 的内置命令read来给变量赋值。
用来提示用户输入信息,从而实现简单的交互过程。执行时将从标准输入设备(键盘)读入一行内容,并以空格为分隔符,将读入的各字段依次赋值给指定的变量(多余的内容赋值给最后一个变量)。若指定的变量只有一个,则将整行内容赋值给此变量。

[root@localhost ~]# read test
123        /等待用户输入,把输入的值赋予test变量
[root@localhost ~]# echo $test
123

一般来说为了使交互式操作的界面更加友好,提高易用性,read命令可以结合"-p"选项来设置提示信息,以便告知用户应该输入什么内容等相关事项

[root@localhost ~]# read -p "请输入你的姓名:" name
请输入你的姓名:zhangsan
[root@localhost ~]# echo $name
zhangsan

交互式定义变量( read)
-p提示用户的信息
-n定义字符数
-t定义超时时间,超过多长时间没输自动退出
-s不显示用户输入的内容,常用于输入密码 read -s -p “input your password:” pass

从文件读取内容赋值给变量
[root@server myscripts]# echo 192.168.100.100 > ip.txt
[root@server myscripts]# cat ip.txt
192.168.100.100
[root@server myscripts]# read -p "input your ip:" IP < ip.txt
[root@server myscripts]# echo $IP
192.168.100.100

变量的作用范围

全局变量和局部变量

默认情况下,新定义的变量只在当前的 shell环境中有效,因此称为局部变量,当进入子程序或新的子
shell环境时,局部变量将无法再使用

[root@localhost ~]# bash#进入子shell环境
[root@localhost ~]# echo $name
[root@localhost ~]# echo $test

export命令:
为了使用户定义的变量在所有的子 shell环境中能够继续使用,减少重复设置工作,可以通过内部命令export将指定的变量导出为全局变量。
用户可以同时指定多个变量名称作为参数(无须使用"s"符号),变量名之间以空格分隔

[root@localhost ~]# exit
exit
[root@localhost ~]# export name test
[root@localhost ~]# bash
[root@localhost ~]# echo $name $testexit
zhangsan 123
或
[root@localhost ~]# echo "$Product $version”
Benet 6.o
[root@localhost ~]# export Productversion #导出为全局变量[root@localhost ~]# bash
[root@localhost ~]# echo "$Product $version"#子程序引用全局变量Benet6.0
[root@localhost ~]# exit

使用export导出全局变量的同时,也可以为变量进行赋值,这样在新定义全局变量时就不需要提前进行赋值了env查看用户当前环境变量
export ABC=123
再次env就能看到了
export -n ABC取消定义的全局变量变成局部变量

3.数值变量的运算

在 Bash shell环境中,只能进行简单的整数运算,不支持小数运算整数值的运算主要通过内部命令expr进行运算符与变量之间必须有至少一个空格。

运算内容:加(+)、减(一)、乘(*)、除(/)、取余(%)
运算符号: ( ( ) ) 和 (( ))和 (())和[ ]
运算命令: expr 和 let
运算工具: bc(系统自带)

expr命令(不仅可以运算,还支持输出到屏幕)常用的几利运算符如下所述。

  • +:加法运算。
  • -:减法运算。
  • :乘法运算,注意不能仅使用"*"符号,否则将被当成文件通配符。
  • /:除法运算。
  • %:求模运算,又称为取余运算,用来计算数值相除后的余数。
例:
[root@localhost~]# expr 1 + 1
2
[root@localhost~]# expr 1+1
1+1
[root@localhost~]# expr 2 * 2
expr:语法错误
[root@localhost~]# expr 2 \* 2  ##乘法*需要转义
4
[root@localhost~]# expr 2 '*' 2   ##乘法也可以用单引号表示但没太大必要因为只有一个字符
4

expr不仅支持常量还支持变量的运算:

例1

[root@localhost ~]# X=35
[root@localhost ~]# Y=16
[root@localhost ~]# expr $X + 5
40
[root@localhost ~]# expr $X + $Y
51
[rootelocalhost ~]# expr $X - $Y
19
[root@localhost ~]# expr $X \* $Y
560
[root@localhost ~]# expr $X / $Y
2
[rootelocalhost ~]# expr $X % $Y
3

例2

sum=`expr $Y \*$Y \* $Y`
echo $sum

例3

#!/bin/ bash
#1.定义输出数宁
read -p "请输入第一个数字:" num1
read -p "请输入第二个数字:" num2

#2.执行加法运算
expr $num1 + $num2
echo "求和数:$sumn"

[ ] 和 []和 []和(())必须要和echo在一起用因为他只能运算无法输出结果

[root@localhost~]# echo $((1+1))
2
[root@localhost~]# echo $((5-2))
3
[root@localhost~]# echo $((a-b))
7
[root@localhost~]# echo $((b-a))  ##可以有负数
-7

$[]整数运算

[root@localhost~]# echo $[10*10]      ##$[]里的*不需要转义
100
[root@localhost~]# echo $[10%8]
2
[root@localhost~]# echo $[10/8]
1
[root@localhost~]# echo $[10/12]
0
[root@localhost~]# echo $[10%12]
10

[ ] 变 量 的 运 算 , 可 省 略 [ ] 里 的 []变量的运算,可省略[]里的 []变量的运算,可省略[]里的

[root@client opt]# echo $[$a+$b]
13
[root@client opt]# echo $[a+b]
13
[root@client opt]# echo $[a-b]
7
[root@client opt]# echo $[a*b]
30
[root@client opt]# echo $[a/b]
3

4.let运算与bc运算

i++  ----  i=$[$i+1]
i--  ----  i=$[$i-1] 
i+=2 ----  i=$[$i+2]

let的运算可以改变变量本身的值,但不显示结果,需要echo,其他的运算方式可以做运算但不改变变量本身的值

[root@localhost~]# n=1;let n=n+1;echo $n
2
[root@localhost~]# let n+=2   #相当于n=n+2
[root@localhost~]# echo $n
4
[root@localhost~]# let n=n**2  #求幂,4的2次方
[root@localhost~]# echo $n
16
[root@localhost~]# let n++    #n自加1
[root@localhost~]# let n--l   #n自减1
[root@localhost~]# echo $n
16
[root@localhost~]# echo $[n++]    #先输出再自增1,这时a的值已经变于
16
[root@localhost~]# echo $n        #输出上面的值
17
[root@localhost~]# echo $[++n]      #先自增1再输出,所以直接输出了变化后的值
18
[root@localhost~]# echo $n
18

使用bc进行运算,支持小数运算,但在脚本中不可直接使用否则会进入交互界面,可以用echo结合管道使用

[root@localhost ~]# bc
bc 1.06.95
copyright 1991-1994,1997,1998,2000,2004,2006 Free Software Foundation,Inc.This is free software with ABSOLUTELY NO WARRANTY.
For details type 'warranty'.
10/ 3
3
scale=3     #指定小数点后几位
10/3
3.333
[root@localhost ~]# echo "scale=3;10/3" | bc
3.333
[root@localhost ~]# echo "3^2" | bc   #做幂的运算,计算3的平方
9

bc做变量的运算:

[root@localhost ~]# a=10
[root@localhost ~]# b=3
[rootelocalhost ~]# echo "$a/$b” | bc
3
[root@localhost ~]# echo "scale=2; $a/$b" | bc
3.33
可以试着算一下圆的面积

bc还可以做逻辑运算,真为1,假为0

[root@localhost ~]# echo "2>2"| bc
0
[root@localhost ~]# echo "2==2" | bc
1
[root@localhost ~]# echo "2<2"| bc
0
常用的运算表达式:
i=$ (expr 12 \* 5)
i=$((12 * 5))
i=[12 * 5]
let i=12*5

i++   相当于 i=$[$i+1]
i--   相当于 i=$[$i-1]
i+=2  相当于 i=$[$i+2]

5.特殊变量

1)环境变量

环境变量指的是出于运行需要而由Linux系统提前创建的一类变量,主要用于设置用户的工作环境,包括用户宿主目录、命令查找路径、用户当前目录、登录终端等

环境变量的值由 Linux系统自动维护,会随着用户状态的改变而改变。
使用env命令可以查看到当前工作环境下的环境变量,对于常见的一些环境变量应了解其各自的用途。

例如,
变量USER表示用户名称,
HONE 表示用户的宿主目录,
LANG 表示语言和字符集,
PwD 表示当前所在的工作目录,
PATH表示命令搜索路径等、
RANDOw表示随机数,会返回0-32767的整数,
USER表示当前账户的账户名称等,

一般都用全大写定义,注意和自定义变量区分

[root@localhost ~]# echo $RANDOM
20315
[roote1ocalhost ~]# echo $HOME
/root
[root@localhost ~]# echo $USER
root
[rootelocalhost ~]# echo $LANG
zh_cN.UTF-8
[rootelocalhost ~]# echo $SHELL
/bin/bash
[root@localhost -]# echo $RANDOM    linux中$random用于生成0-32767的随机数18945
18945

PATH路径环境变量:
PATH变量用于设置可执行程序的默认搜索路径,当仅指定文件名称来执行命令程序时,系统将在PATH变量指定的目录范围查找对应的可执行文件,如果找不到则会提示"command not foundw“

[root@localhost ~]# test.sh
bash: test.sh:未找到命令...
[root@localhost ~]# echo $PATH
/usr/local/sbin:/usr/locai/bin:/usr/sbin:/usr/bin:/root/bin
[root@localhost ~]# pwd
/root

这时因为test.sh不在$PATH的目录里面,所以系统无法识别无法直接用,需要跟上绝对路径使用该脚本

方法一:

将脚本的目录加入$PATH
[root@localhost ~]# PATH="$PATH:/root"
//这时临时的,
如果永久生效需要编辑/etc/profile文件
[root@localhost ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root
[root@localhost ~]# test.sh
hello world

方法二:

将你自己写的脚本放到 P A T H 中 的 某 一 个 目 录 在 L i n u x 系 统 中 , 环 境 变 量 的 全 局 配 置 文 件 为 / e t c / p r o f i l e , 在 此 文 件 中 定 义 的 变 量 作 用 于 所 有 用 户 。 除 此 之 外 , 每 个 用 户 还 有 自 己 的 独 立 配 置 文 件 (   / . b a s h p r o f i l e ) 。 修 改 完 了 要 重 新 登 陆 才 能 生 效 , 如 果 想 立 即 生 效 , 可 以 使 用 s o u r c e 注 意 : 修 改 PATH中的某一个目录 在Linux系统中,环境变量的全局配置文件为/etc/profile,在此文件中定义的变量作用于所有用户。除此之外,每个用户还有自己的独立配置文件(~/.bash_profile)。 修改完了要重新登陆才能生效,如果想立即生效,可以使用source 注意:修改 PATH中的某一个目录在Linux系统中,环境变量的全局配置文件为/etc/profile,在此文件中定义的变量作用于所有用户。除此之外,每个用户还有自己的独立配置文件( /.bashp​rofile)。修改完了要重新登陆才能生效,如果想立即生效,可以使用source注意:修改PATH需要慎重操作,如果找不到了会影响命令的使用!!!

例如:
[root@localhost ~]# PATH=        #手误将PATH设为空
[root@localhost ~]# echo $PATH
[root@localhost ~]# ls
-bash: ls:没有那个文件或目录

2)只读变量

shell变量中有一种特殊情况,一经设定,其值是不可改变的,这种变量被称为只读变量。
在创建变量的时候可将其设置为只读属性,也可以将已存在的变量设置为只读属性,
只读变量主要用于变量值不允许被修改的情况,只读变量不可以改变值也不可以被删除

[root@localhost ~]# test=123
[root@localhost ~]# readonly test
#readonly用来定义只读变量,一旦使用readonly定义的变量在脚本中就不能更改
[root@localhost ~]# echo $test
123
[root@localhost ~]# test=456
-bash: test:只读变量
[root@localhost ~]# unset test
-bash: unset: test:无法反设定:只读variable
暂时设定,只需要退出登陆即可恢复

3)位置变量

当执行命令行操作时,第一个字段表示命令名或脚本程序名,其余的字符串参数按照从左到右的顺序依次赋值给位置变量。
位置变量也称为位置参数,使用$1、$2、$3、…、$9表示
命令或脚本本身的名称使用"$0”表示

例:编写一个简单的创建用户和密码的脚本
[root@localhost ~]# vim user.sh
#!/bin/bash
useradd $1
echo $2 | passwd --stdin $1
##退出vim编辑器 执行脚本
[root@localhost ~]# bash user.sh sj 123
更改用户sj的密码。
passwd:所有的身份验证令牌己经成功更新。
[root@localhost ~]# id sj
uid=1001(sj)gid=1001(sj)组=1001 (sj)

例:
[rootelocalhost ~]# vim adder2num.sh
#!/bin/bash
SUM=`expr $1 + $2`
echo "$1 + $2 = $SUM”

[root@localhost ~]# chmod +x adder2num.sh
[root@localhost ~]# ./adder2num.sh 12 34 
#$1为 12   $2为 34  的情况 12 + 34 = 46
[root@localhost ~]# ./adder2num.sh 56 78 
#$1为 56   $2为 78  的情况 56+ 78 = 134


4)预定义变量

预定义变量是由 Bash程序预先定义好的一类特殊变量,用户只能使用预定义变量,而不能创建新的预定义变量,也不能直接为预定义变量赋值。预定义变量使用"$"符号和另一个符号组合表示

  • $#:表示命令行中位置参数的个数。
  • $*:表示所有位置参数的内容,这些内容当做一个整体
  • $@:表示列出所有位置参数,但是是以单个的形式的列出
  • $?:表示前一条命令执行后的返回状态,返回值为О表示执行正确,返回任何非О值均表示执行出现异常。
  • $0:表示当前执行的脚本或程序的名称
  • $$:表示返回当前进程的进程号
  • $!:返回最后一个后台进程的进程号

例:根据一个简单的脚本来理解每个预定义和位置变量的含义

#!/bin/bash
echo $1
echo "$0 表示当前执行的脚本或程序的名称"
echo "$# 表示命令行中位置参数的个数"
echo "$* 所有位置参数的内容,这些内容当做一个整体"
echo "$@ 表示列出所有位置参数,但是是以单个的形式的列出”

例2:可以将脚本做下优化

#!/bin/bash
echo "当前脚本名称为$o"
echo "当前脚本的第一个参数是$1"
echo "当前脚本的第二个参数是$2"
echo "当前脚本一共有$#个参数"

例3 touch /home/ kgc.txt &

echo "$$  表示返回当前进程的进程号"
echo "$?  0正确,1"
echo "$!  返回最后一个后台进程的进程号"

理解$*和 $@的区别

  • ∗ 、 *、 ∗、@:表示命令或脚本要处理的参数。
  • $*:把所有参数看成以空格分隔的一个字符串整体(单字符串)返回,代表"$1 $2 $3 $4"。
  • $@:把各个参数加上双引号分隔成n份的参数列表,每个参数作为一个字符串返回,代表"$1""$2""$3""$4"。

在脚本中加入以下两行内容然后执行

touch "$*"
touch "$@"

ls -l查看创建了哪些文件

总结:
$*是将参数全部当做一个整体
$@是将参数每一个都当做单独的个体

set:查看系统所有的变量,包括环境变量和自定义变量(没有单独查看自定义变量的命令,可以set管道过滤)

标签:Shell,变量,编程,echo,shell,bash,root,localhost
来源: https://blog.csdn.net/qxdbb/article/details/122592480

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有