shell脚本编程

Shell脚本是包含一些命令或声明,并符合一定格式的文本文件。

程序:指令+数据

程序编程风格

过程式  以指令为中心,数据服务于指令。

对象式  以数据为中心,指令服务于数据。

Shell程序:提供了编写和能力,解释执行。

编程逻辑处理方式:

          顺序执行

          循环执行

          选择执行

Shell编程:过程式,解释执行

编程语言的基本结构

          数据存储:变量,数组

          表达式:  a+b

          语句:    if

创建shell脚本

第一步  使用文本编辑器来创建文本文件,第一行必须包括shell声明序列:#!

          eg: #!/bin/bash

             #!author:

             #!version:

             #!descriptio:

             脚本正文

             :wq (保存)

第二步  运行脚本 

        给予执行权限,在命令行上指定脚本的绝对路径或相对路径。

        直接运行解释器,将脚本最为解释器程序的参数执行。

    

当执行shell脚本时,比如说将脚本存放在/testdir目录中执行时要将该脚本的绝对路径或相对路径写上。

          例如:

            绝对路径     /testdir   test.sh

            相对路径      ./test.sh

如果不写脚本的路径时,系统找的是$PATH变量的路径,当前脚本的路径不在$PATH变量的路径中时,该脚本是不会运行的。

在linux中。系统执行程序时,是不去找当前路径的,即便程序就在当前路径中,也是只搜$PATH变量。

如果希望程序能在当前路径下运行,我们可以用修改$PATH变量的方法来实现。

以修改root的$PATH变量为例,在root的家目录下有一隐藏文件 .bash_profile。用vim打开.bash_profile文件,修改PATH=$PATH:$HOME/bin。在bin后面加“:.”后面的点表示当前路径。

blob.png

在PATH=$PATH:$HOME/bin:.这条命令中,脚本的执行顺序是:先找$PATH再找$HOME/bin,最后找当前路径,所以将“· ”放到最前也是可以的。

当vim设置好保存退出后。$PATH不能及时生效,需要执行 . .bash_profile,$PATH才能生效。

最后在当前路径下执行一个脚本测试是否运行,运行则修改成功,不运行则修改未成功。

但是一般不将当前路径添加进$PATH这样做不安全。

变量

   变量:命名的内存空间

   数据存储的方式:

             字符

             数值:整型    浮点型

      命令执行优先级:别名→内部命令→hash到内存中的外部命令→外部命令

  变量类型:

          作用:

               数据存储格式

               参与的运算

               表示的数据范围

变量命名的法则:

              不能使用程序中的保留字,例如if    for

              可以使用数字、字母及下划线,但是不能以数字开头。

              见名知义。

              同一命名规则。 

          管理员自己定义$PATH变量

          例如:var1=test   这个var1变量的内容就是test,不区分大小写。

               blob.png

变量的名称可以随便起。但是数字例外,组合也是可以的,但是数字不能开头。

定义完成后,如果该变量不想要了也可以删除,执行unset var1。不用再var1前面加”$”,因为unset是专门删除变量的。

用echo $var1验证,不会显示结果。代表unset执行成功,但是系统会生成一个空的$var1。

变量用完后应及时用unset删除,如果不删除,则变量会一直存在于内存中,消耗内存资源。

Set命令可以查看所有变量

变量种类

   本地变量

       直接在当前的脚本或shell中直接写一个变量的赋值,比如说:var1=test,var1这个

   变量是基于本地的,只能在本地终端中用,换个终端就无法执行了。

     

编写第一个脚本   Var.sh

blob.png

当我们将在脚本中定义好的脚本中的变量var1=haha拿到外面echo $var1执行的时候,是没有结果的,说明var1这个变量只能在脚本内起作用。执行var.sh这个脚本的时候,执行结果也是为空。

将var.sh脚本稍作修改

blob.png

当再去执行var.sh脚本的时候,显示了$var1的变量结果:haha,所以该变量只能自己用。

blob.png

编写第二个脚本  var2.sh

    blob.png

执行var2.sh脚本。显示了$var2的变量结果:xixi

blob.png

这两个脚本各自显示各自的变量值,互不影响。

将var.sh这个变量稍作修改,让其调用var2.sh

    

  blob.png

执行var.sh脚本  分别显示了var.sh的值,也显示了var2.sh的值

blob.png

将var2.sh脚本稍作修改

blob.png

执行var2.sh

blob.png

上图显示第二行var2.sh中显示的是空。当var2.sh尝试去调用$var1的变量结果的时候,没有成功,因为$var1变量是在var.sh中定义的,var2,sh本身没有,所以调用失败。

可以讲var.sh与var2.sh做个对比

blob.png

blob.png

从上图的对比中可以看出,var.sh不仅显示了自己的执行结果,还调用了var2.sh的执行结果。但是var2.sh显示了自己的执行结果,但是当它尝试去调用$var1变量的的结果的时候却失败了,因为$var1的变量是定义在var.sh脚本中的,其本身并没有,所以无法直接调用。

Var.sh调用var1.sh,其调用的关系就是父子进程的关系。

本地变量的有效范围是不能直接在当前shell中有效,甚至是子进程都不能使用。

环境变量

    环境变量具有继承性,在变量前夹export就可以将$v1变量继承下去。

新建脚本var1.sh

blob.png

    var1.sh脚本不仅显示自己的结果,还去调用var2.sh的结果。

新建脚本var2.sh

blob.png

    var2.sh脚本不仅显示自己的结果,还去调用$v2变量和var3.sh脚本的结果    

新建脚本var3.sh

blob.png

var3.sh脚本调用$v1变量的结果。

当执行var1.sh的时候,var2.sh  var3.sh都可以调用$v1变量的结果。

blob.png

只读变量

也称为常量,比如定义圆周率,P=3.14159。有可能会被修改。如果不想被修改,则用readonly将P定义为只读变量,便无法修改。

只读变量甚至删业无法执行,除非程序退出,再进入,则只读变量自动消失。

blob.png

位置变量

新建脚本test.sh

 blob.png   

执行test.sh脚本

blob.png

上图中,$1相当于 aa ,$2相当于bb,$3想当于cc,$*相当于aa  bb  cc  dd。

在脚本代码中,调用通过命令行传递给脚本的参数。

$1 、$2……….对应第一、第二个参数。Shift[n]表示换位置

             $0    代表命令本身

             $*    传递给脚本的所有参数,全部合为一个字符串

             $@   传递给脚本的所有参数,每个参数都为独立的字符串

             $#    传递给脚本的参数的个数

逻辑运算

True      false

     1         0

            与:                               或:   

           1 与 1 = 1                          1 或 1 = 1 

           1 与 0 = 0                          1 或 0 = 1

           0 与 1 = 0                          0 或 1 = 1

           0 与 0 = 0                          0 或 0 = 0

逻辑运算

 非:!

! 1 = 0

! 0 = 1

 短路运算:

短路与:

第一个为0,结果必定为0;

第一个为1,第二个必须要参与运算;

短路或:

第一个为1,结果必定为1;

第一个为0,第二个必须要参与运算;

 

异或: ^

异或的两个值,相同为假,不同为真。

Exp1=exp2      假

Exp1!=exp2    真

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

(0)
zzdzzd
上一篇 2016-08-15 09:24
下一篇 2016-08-15 09:24

相关推荐

  • 编译内核——制作最适合自己系统的内核

    编译内核: ·程序包的编译安装:         ./configure ,make ,make install ·前提:开发环境(开发工具、开发库),头文件:/usr/include ·开源:源代码–>可执行格式    &nbsp…

    Linux干货 2016-09-11
  • Linux中的cut、sort、uniq以及用户(组)管理类指令应用示例

    Linux中的cut、sort、uniq指令 列出当前系统上所有已经登录的用户的用户名,注意:同一用户登录多次,只显示一次。 解决思路: 先使用who指令显示出所有已登录的用户。然后对who指令的输出进行切割得到想要的第一列内容,即只包含用户名。可以使用cut指令。最后对cut的结果进行排序并去重。可以使用sort指令。   借助管道符,可以方便的…

    Linux干货 2016-11-13
  • 文件查找工具之——find

        前言:Linux一切皆文件,在linux的系统中如果我们需要找到所需的文件,除了一步一步慢慢找,还有一种办法就是要使用Linux中查找文件工具命令,能让我们很快定位到我们所需的文件。所以我们必须要学好文件查找工具 一、首先我们先要了解文本搜索和文件查找的区别     文本…

    Linux干货 2015-07-06
  • 抓包获取QQ好友IP地址

    作者:网海过客 原文连接:https://www.chinasa.net/archives/326.html 原理:通过抓包软件,抓取QQ进程,向QQ好向发送UDP数据包,获取QQ好友IP地址 抓包软件:科来网络分析系统 步骤: 1、打开抓包软件,选择网卡,本地进程分析。 2、向QQ好友发起语音通话 3、在抓包软件里,找到QQ进程,数据包,过滤UDP协议,在…

    Linux干货 2017-06-30
  • N22-love cat第19周 – 基于Apache + Tomcat +2种模式实现负载均衡以及配置集群seesion服务

      基于Apache+Tomcat实现负载均衡和集群服务 一、概念     从Tomcat权威指南中的测试数据,我们不难发现,对于静态页面的数据,Tomcat的处理速度比Apache要快很多,所以为什么要整合apache虽然在处理静态页面速度上比Apache快,但是Tomcat经不起大的并发量容易死。为此,我们就需要A…

    Linux干货 2016-08-29
  • Net25-第9周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash for line in `cat /etc/passwd`;do if [[ `echo $line | awk -F: ‘{print $7}’` == ‘/sb…

    Linux干货 2017-03-15

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-15 10:21

    总结的很详细,并且通过具体操作加深了自己对变量的理解,