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

相关推荐

  • dd工具

    dd     dd命令:convert and copy a file     用法:        ddif=/PATH/FROM/SRC of=/PATH/TO/DEST       &…

    Linux干货 2016-09-02
  • 树 非线性结构 树是n(n >= 0)个元素的集合: (1)每个元素称为结点(node); (2)有一个特定的结点,称为根结点或根(root); (3)除根结点外,其余结点被分成m(m>=0)个互不相交的有限集合,而每个子集又都是一棵树(称为原树的子树Subtree) 注意 n = 0时,称为空树 树只有一个特殊的没有前驱的元素,称为树的根(Ro…

    2017-10-16
  • 磁盘管理之swap,移动设备及dd命令的使用

    首先我们来复习一下前一天的内容 CHS Sector(扇区) 512字节 track(磁道) 63个 2^6个扇区 1024个磁道,10个位存储磁道数 track=cylinder(柱面) cylinder=(容量)sector(512)track(63)head(256)=8M head(磁头) 256 8位存储 MBR的分区方式都是基于柱面为整…

    Linux干货 2016-09-07
  • 第二周作业

    一Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 which命令:显示(shell)命令全部的路径 which [option] programmame […] –skip-alias:忽略别名   whereis命令:搜索二进制程序,源码,和帮助手册页的命令 whereis [option] na…

    Linux干货 2017-02-18
  • Linux 文件系统权限

    一、简述权限  文件系统的权限管理机制的建立,约束了用户对数据的操作。 1、对系统安全而言  管理员的操作权限非常大,足以破坏系统,权限机制将管理员与普通用户之间区分开,防止系统被随意破坏。 2、对用户而言  Linux是一个多用户的操作系统,不同用户间为了防止其他人破坏数据或访问数据,文件系统的权限管理是非常必要的。 二、文件…

    Linux干货 2016-08-04
  • 那些年我们一起追过的缓存写法(二)

    原文出处: 蘑菇先生   上次主要讨论缓存读写这块各种代码实现。本篇是就上次的问题接着来,继续看那些年我们各种缓存用法。 一:缓存预热 上次有同学问过。在第一次加载时,我们的缓存都为空,怎么进行预热。 单机Web情况下,一般我们使用RunTimeCache。相对于这种情况下: 1:我们可以在启动事件里面刷新 1 2 3 4 vo…

    Linux干货 2015-03-04

评论列表(1条)

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

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