Shell 脚本调用另一个脚本的三种方法

文章介绍了在Shell脚本中调用其他脚本的三种方式:source、点号和sh命令,以及它们之间的区别,特别是环境变量的访问。使用source和点号会在当前进程中执行,而sh命令会启动新进程,无法访问父进程的变量。通过export命令可以设置临时环境变量,使得子进程能访问这些变量。此外,文章还提到了如何设置永久环境变量,包括在/etc/profile、~/.bash_profile和~/.bashrc文件中添加变量。
摘要由CSDN通过智能技术生成

https://blog.csdn.net/k346k346/article/details/86751705

文章目录

1.source

2.点号.

3.sh 命令

4.三者的区别

5.export 命令设置临时环境变量

6.export 命令设置永久环境变量

参考文献

假如有脚本 first.sh:

#!/bin/bash

#------------------

#@file:first.sh

#------------------

echo 'your are in first file'

如何在其它Shell脚本中调用first.sh呢?主要有三种方法:source、点号以及sh命令。

1.source

#!/bin/bash

#---------------

#@file:second.sh

#---------------

echo 'your are in second file'

source first.sh

2.点号.

#!/bin/bash

echo 'your are in second file'

. first.sh

注意,点号与脚本文件之间记得要有空格。

3.sh 命令

#!/bin/bash

echo 'your are in second file'

sh first.sh

三者输出的结果都是:

your are in second file

your are in first file

4.三者的区别

使用 source 命令和点号是等价的,类似于 C/C++ 中的 #include 预处理指令,都是将指定的脚本内容拷贝至当前的脚本中,由一个 Shell 进程来执行。使用sh命令来调用另外的脚本和前面两种方法有着本质的区别。使用sh命令则会开启新的Shell进程来执行指定的脚本,这样的话,父进程中的变量在子进程中就无法访问。参考如下代码:

first.sh 内容如下,访问了 second.sh 中的变量 second。

#!/bin/bash

echo 'your are in first file'

echo 'second:' $second

second.sh内容,通过上面介绍的三种方法来调用first.sh,看看对second.sh的变量second访问有什么区别!

#!/bin/bash

second=lvlv

echo 'your are in second file'

source first

. first

sh first

程序的输出结果是:

your are in second file

your are in first file

second: lvlv

your are in first file

second: lvlv

your are in first file

second:

可见,使用sh命令开启一个子进程来调用指定的shell脚本无法访问父进程的变量。我们如何让子进程访问父进程中变量呢?可以使用 export 命令。

5.export 命令设置临时环境变量

我们需要知道 Shell 中按照变量的作用域和生命周期,Shell 变量可分为四大类:

(1)永久环境变量

需要修改配置文件,变量永久生效。

(2)临时环境变量

使用export命令行声明即可,变量在shell脚本进程结束后仍然有效,但在关闭当前shell会话后失效。

(3)全局变量

在脚本中定义,仅在当前Shell脚本中有效,其他Shell脚本进程不能访问,其作用域从定义的位置开始,到脚本结束或被显示删除的地方为止。注意,全局变量既可以在Shell函数内定义,也可以在Shell函数外定义,因为Shell函数内定义的变量默认为 global,且作用域从“函数被调用时执行变量定义的地方”开始,到脚本结束或被显示删除的地方为止。

#!/bin/bash

globalVar=dablelv#全局变量

(4)局部变量

在 Shell 函数内显示使用 local 关键字定义的变量。其作用域局限于函数内。同名local变量会屏蔽global变量。

#!/bin/bash

function test() {

local localVar=dablelv#局部变量

}

test

echo $localVar #输出为空

所以,使用export命令我们申明的是临时环境变量,在当前shell会话中,所有的shell实例都可以访问由export命令申明的临时环境变量。因为当前shell会话中的所有shell实例,都是当前shell会话的子进程,所以可以与父进程一同访问环境变量。

second.sh 修改如下:

#!/bin/bash

export second=lvlv

echo 'your are in second file'

sh first.sh

执行second.sh将输出:

your are in second file

your are in first file

second: lvlv

至此,通过 export 命令设置临时环境变量的方式,使得Shell子进程能够访问父进程中的变量。

6.export 命令设置永久环境变量

那么如何定义永久环境变量呢?可以采用如下三种方法:

(1) 在/etc/profile文件中添加环境变量,对所有用户永久生效。例如通过 vim 编辑/etc/profile文件,在最后一行添加 CLASSPATH 变量。

export CLASSPATH=./JAVA_HOME/lib;$JAVA_HOME/jre/lib

1

注意,修改文件后要想马上生效需要执行source /etc/profile 或 . /etc/profile,不然只能在下次重新登录时才生效。

(2) 在~/.bash_profile文件中添加环境变量,只对当前用户永久有效。例如通过 vim 编辑~/.bash_profile文件中添加环境变量。

export CLASSPATH=./JAVA_HOME/lib;$JAVA_HOME/jre/lib

注意: 修改文件后要想马上生效需要执行source ~/.bash_profile 或 . ~/.bash_profile,不然只能在下次重新登录时才生效。

(3)在~/.bashrc文件中添加环境变量,只对当前用户永久有效。例如通过 vim 编辑~/.bash_rc文件中添加环境变量。

export CLASSPATH=./JAVA_HOME/lib;$JAVA_HOME/jre/lib

注意:

修改文件后要想马上生效需要执行source ~/.bash_rc 或 . ~/.bash_rc,不然只能在下次重新登录时才生效;

~/.bash_profile会显式调用~/.bashrc文件,而~/.bashrc显式调用/etc/bashrc文件。

另外,如想删除已设置的环境变量,可以使用 unset(builtin)命令来清除环境变量 ,例如$unset CLASSPATH。使用readonly命令可设置只读变量。如果使用了readonly命令的话,变量不可以被修改或清除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值