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命令的话,变量不可以被修改或清除。