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

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

参考:
1. Linux中shell的变量分类(环境级变量、用户级变量和系统级变量)

一、系统中变量的分类
在 shell 中变量分为环境级变量、用户级变量、系统级变量这三种

环境级变量只在当前 shell 中生效, shell 关闭变量丢失
用户级变量写在用户的骨文件(.bash_profile)中,只针对当前用户生效,切换用户后就不再生效
系统级变量被写在系统的配置文件 /etc/profile 或者 /etc/profile.d/ 中,对于所有用户都生效

    环境级变量只在当前 shell 中生效, shell 关闭变量丢失 直接在shell当中设置
    用户级变量写在用户的骨文件中,只针对当前用户生效 用户的骨文件一般都在用户的家目录下面(ls -a 查看隐藏的文件).bash_profile
    cd /etc/skel这个目录下面存放的是新建用户的骨文件,也是隐藏文件
    系统级变量被写在系统的配置文件 /etc/profile 或者 /etc/profile.d/ 中,对于所有用户都生效

二、变量的定义方法
环境级:直接在shell中输入export A=1来定义变量
用户级:编辑家目录下面的用户级文件 vim ~/bash_profile,写入export A=1来定义变量
系统级:编辑系统的配置文件vim /etc/profile,写入export A=1来定义变量
————
原文链接:https://blog.csdn.net/CapejasmineY/article/details/100017705

============================

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

假如有脚本 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。

first.sh :

#!/bin/bash
echo 'your are in first file'
echo 'second:' $second

 

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

second.sh :

#!/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:

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

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

(1)永久环境变量:需要修改配置文件,变量永久生效。

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

(3)全局变量:在脚本中定义,仅在当前Shell脚本中有效,其他Shell脚本进程不能访问,其作用域从定义的位置开始,到脚本结束或被显示删除的地方为止。

注意,全局变量既可以在Shell函数内定义,也可以在Shell函数外定义,因为Shell函数内定义的变量默认为global,且作用域从“函数被调用时执行变量定义的地方”开始,到脚本结束或被显示删除的地方为止。

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子进程能够访问父进程中的变量。

------------------------------------------

Shell 变量的作用域可以分为三种:
有的变量只能在函数内部使用,这叫做局部变量(local variable);
有的变量可以在当前 Shell 进程中使用,这叫做全局变量(global variable);
而有的变量还可以在子进程中使用,这叫做环境变量(environment variable)。
———
版权声明:本文为CSDN博主「sg-expert」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zjc156m/article/details/118582021

------------------------------------------

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

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

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

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

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

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

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

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

另外,如想删除已设置的环境变量,可以使用 unset(builtin)命令来清除环境变量 ,例如:

$unset CLASSPATH

使用 readonly命令可设置只读变量。如果使用了readonly命令的话,变量不可以被修改或清除。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值