bash变量详解

   shell作为用户和Unix/Linux沟通的桥梁,既可以是一个可执行的二进制程序,同时也是一个具备了编程能力的程序设计语言,定义了各种各样的变量和参数,下面介绍一下shell之上的各种变量。

1、本地变量

   特性:只对当前shell生效

[root@centos7 ~/bin]#cat localvar1.sh 
#!/bin/bash
#
var1=hei
echo "localvar1:$var1"
localvar2.sh
[root@centos7 ~/bin]#cat localvar2.sh 
#!/bin/bash
var2=ha
echo "localvar2:var2 is "$var2""
echo "localvar2:var1 is "$var1""
[root@centos7 ~/bin]#localvar1.sh 
localvar1:hei
localvar2:var2 is ha
localvar2:var1 is

    localvar1脚本中输出var1变量之外,还执行了localvar2脚本,同时打开了一个子shell,而在localvar2中,不仅输出var2变量,还要输出前一个shell中定义的var1。因为本地变量只对当前shell有效,所以子shell中输出不成功。

2、环境变量

[root@centos7 ~/bin]#cat localvar1.sh 
#!/bin/bash
#
export var1=hei
echo "localvar1:$var1"
localvar2.sh
[root@centos7 ~/bin]#localvar1.sh 
localvar1:hei
localvar2:var2 is ha
localvar2:var1 is hei

   注意:还是上述例子,只需将localvar1中的var1定义为环境变量,localvar1中定义的var1的作用范围将扩展至当前shell及其子shell,所以localvar2中可以输出var1。

3、特殊变量

   <1>区分$*和$@

[root@centos7 ~/bin]#cat arg1.sh 
#!/bin/bash
#
arg2.sh "$*"
echo --------------
arg2.sh "$@"
[root@centos7 ~/bin]#cat arg2.sh 
#!/bin/bash
echo "First parameter is $1"
echo "Second parameter is $2"
[root@centos7 ~/bin]#arg1.sh a b
First parameter is a b
Second parameter is 
--------------
First parameter is a
Second parameter is b

    执行arg1脚本时,实际上是通过将$*和$#作为参数赋予脚本arg2,来执行arg2,子shell中执行的arg2脚本再通过位置变量将这俩个参数输出,进而区分$*和$@的区别。得出结论:$*将全部参数作为一个字符串,而$#将全部参数识别为独立的字符串。 

    <2>认识$#,$0,$?

[root@centos7 ~/bin]#cat test.sh 
#!/bin/bash
#
echo $0
echo $#
[root@centos7 ~/bin]#echo $?
0

    上面可以看出:$0是脚本的名称,$#是参数的个数,而$?是测试上一条命令是否执行成功。

4、位置变量

[root@centos7 ~/bin]#cat countdao.sh 
#!/bin/bash
#
echo "$1 $2 $3 $4 $5 $6 $7 $8 $9 ${10} $11 $12"
[root@centos7 ~/bin]#countdao.sh a b c
a b c        a1 a2
[root@centos7 ~/bin]#countdao.sh z b c
z b c        z1 z2

    位置变量中$1..$9正常识别,$10将被识别为$1+1,解决方法$10–>${10}

    注意:在bash中位置变量也是有上限的,如果要测试,可使用以下代码

[root@centos7 /tmp]#cat testpa.sh 
#!/bin/bash
#Author:Zhao
#Name:testpa.sh
#Function:Test the maximum value of the script can accept
echo $200000                
[root@centos7 /tmp]#bash testpa.sh `echo {1..200000}`
200000       -----------------此处小编只测试到200000,大家可以加大数值

5、局部变量

   特点:只对特定的代码片段生效

强化练习

1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小

#!/bin/bash
#Author:Zhao
#Name:Systeminfo
#Function:A brief description of the system infomation
#---------
IP=`ifconfig | sed -n '2p' | tr -s ' ' | cut -d' ' -f3`
OS_Version=`cat /etc/centos-release`
Kernel=`cat /etc/centos-release`
CPU_Model=`cat /proc/cpuinfo | grep "model name" | sed -r 's@.*[[:space:]](i7.*)@\1@'`
Disk_Available=`fdisk -l | sed -n '2p' | tr ',' ':' | cut -d: -f2`
Memory=`cat /proc/meminfo | head -1 | sed -r 's@^.*[[:space:]]([[:digit:]]+.*)@\1@'`

echo "IP:$IP"
echo "OS_Version:$OS_Verson"
echo "Kernel:$Kernel"
echo "CPU_Model:$CPU_Model"
echo "Disk_Available=$Disk_Available"
echo "Memory:$Memory"

unset IP
unset OS_Version
unset Kernel
unset CPU_Model
unset Disk_Available
unset Memory

2、编写脚本/root/bin/backup.sh,可实现手动将/etc/目录备份到/root/etcYYYY-mm-dd中

#!/bin/bash
#Author:Zhao
#Name:backup.sh
#Function:Backup /etc directory

cp -a /etc/ /root/etc`date +%F`

3、编写脚本/root/bin/disk.sh,显示当前硬盘分区中空间利用率最大的值

#!/bin/bash
#Author:Zhao
#Name:disk.sh
#Function:Query disk usage

Maxdisk=`df | grep -v "media" | grep dev | tr ' ' ':' | tr -s ':' | cut -d: -f1,5 | sort -t: -k2 | tail -1`
echo "Maximum disk usage is:$Maxdisk"

unset Maxdisk

4、编写脚本/root/bin/links.sh,显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序

#!/bin/bash
#Author:Zhao
#Name:links.sh
#Function:Query current numbers of connection

links=`netstat -tn | grep tcp | tr -s ' ' | cut -d' ' -f5 | sort -r`
echo -e "The numbers of connection are\n$links"

unset links

5、写一个脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和

#!/bin/bash
#Author:Zhao
#Name:sumid.sh
#Function:Calculate the sum of ID

line1=10
line2=20
ID1=`sed -n ''$line1'p' /etc/passwd | cut -d: -f3`  -----特别注意sed处的变量替换的写法
ID2=`sed -n ''$line2'p' /etc/passwd | cut -d: -f3`
sumid=$[$ID1+$ID2]
echo "The sum of ID is:$sumid"

unset line1
unset line2
unset ID1
unset ID2
unset sumid

6、写一个脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和

#!/bin/bash
#Author:Zhao
#Name:sumspace.sh
#Function:Calculate the number of blank lines

line1=`grep "^$" $1 | uniq -c`
line2=`grep "^$" $2 | uniq -c`
linesum=$[$line1+$line2]
echo "The number of blank lines is: $linesum"

unset line1
unset line2
unset linesum

7、写一个脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录中共有多少个一级子目录和文件

#Author:Zhao
#Name:sumspace.sh
#Function:Calculate the number of directorys and files

etc_file=`ls -A /etc | wc -l`
var_file=`ls -A /var | wc -l`
usr_file=`ls -A /var | wc -l`

file_sum=$[$etc_file+$var_file+$usr_file]
echo "The sum of directory and files is:$file_sum"

unset etc_file
unset var_file
unset usr_file

7、写一个脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果参数个数不小于1,则显示第一个参数所指向的文件中的空白行

#!/bin/bash
#Author:Zhao
#Name:links.sh
#Function:Query current numbers of connection

[ $# -lt 1 ] && (echo "At least input a parameter"; exit) || (`grep "^$" $1 | wc -l` && echo "The blank lines is:$blank")

unset blank

8、写一个脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”

#!/bin/bash
#Author:Zhao
#Name:hostping.sh
#Function:Test whether the IP address can communicate

IP1=`echo $1 | grep -E -o "(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])"`
[[ $1 == $IP1 ]] && (echo "legal IP"; ping -c1 -W1 $1 &> /dev/null && echo "The IP address can be accessed" || echo "The IP address can't be accessed") || echo "Illegal IP"; exit

unset IP1

9、chmod -rw /tmp/file1,编写脚本/root/bin/per.sh,判断当前用户对/tmp/fiile1文件是否不可读且不可写

#!/bin/bash
#Author=Zhao
#Name:per.sh
#Function:Test user's permissions for file

File=/tmp/file1
Who=`whoami`
[ ! -r $File -a ! -w $File ] && echo "Don't have read and write permissions,$Who" || [ ! -r $File ] && echo "No read permission,$Who" || [ ! -w $File ] && echo "No write permission,$Who"

unset File
unset Who

注意:上面这个例子如果拿root测试会出现问题

10、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统。

#!/bin/bash
#Author=Zhao
#Name:per.sh
#Function:Test user's permissions for file

File=/etc/nologin
[ -f $File ] && echo "No login system" || (touch $File; echo "System Locked")

unset File
#!/bin/bash
#Author:Zhao
#Name:login.sh
#Function:Make users can login system

File=/etc/nologin
[ -f $File ] && (rm -f $File; echo "System Unlocked") || echo "You can login system"

unset File

12、计算1+2+3+…+100的值

#!/bin/bash
#Author:Zhao
#Name:sum.sh
#Function:Calculate the sum of figures

sum=`echo {1..100} | tr ' ' '+' | bc`
echo "{1..100} sum is:$sum"

unset sum

13、计算从脚本第一参数A开始,到第二个参数B的所有数字的总和,判断B是否大于A,否提示错误并退出,是则计算之

#!/bin/bash
#Author:Zhao
#Name:sum2.sh
#Function:Calculate the sum of figures

sum=`seq $1 $2 | xargs | tr ' ' '+' | bc`
[ $2 -gt $1 ] && echo "{A..B} sum is:$sum" || echo "Error input"

unset sum

原创文章,作者:mfwing,如若转载,请注明出处:http://www.178linux.com/34649

(0)
mfwingmfwing
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • 计算机的组成和其功能

    图:计算机组成架构 计算机由硬件和软件组成 硬件部分: CPU:又称中央处理器,整个系统最高执行单元,执行各种运算,控制电脑自动协调地完成各种操作。 主板:它把计算机的各个部件紧密的连接在一起,各个部件通过主板进行数据传输,计算机重要的“交通枢纽”都在主板上,他的工作稳定性影响整机的工作稳定性。因同CPU的插脚和性能不同,所以针对不同的CPU也有不同的主板。…

    Linux干货 2016-08-08
  • vim使用方法

    vim是vi的增强版本,具有比vimi更加强大的功能,对于尤其适合编写脚本,下面总结一下vim的常用方法。 vim三种工作模式。         1. 编辑模式:          &nbs…

    2015-03-18
  • Linux系统文本处理

                                           Linux系统文本处理工具        …

    Linux干货 2016-08-15
  • Memcached实现Tomcat的session会话绑定

    memcached介绍:  Memcached是一个高性能的分布式内存对称缓存系统;通过缓存查询数据库结果,介绍数据库访问次数,以提高web应用的速度、提高扩展性。  Memcached特点:   协议简单   基于libevent的事件处理   内置内存存储方式  memcached不互相通信的分…

    Linux干货 2015-08-01
  • linux 学习之权限优先级

    linux下对同一文件的权限分成很多类,同时也可能对同一文件权限配置多种权限那么在这么多配置中,到底是怎么生效的呢?比如一个文件abc.txt属于wang用户,而同时对abc.txt又设置了ACL禁止 wang用户读写执行等等这些情况就是ACL的生效顺序完全理解,模拟出实验环境一一验证1,文件a属于mage用户,但ACL限制 mage读写执行 Paste_I…

    Linux干货 2017-05-29

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-16 16:58

    通过示例演示了各个变量之间的区别,最好能总结一下实验中结果,通过一句话能描述出来,这样以后自己复习过程中也会轻松很多哦