shell脚本export变量只限脚本内么_shell脚本调用oracle存储过程

shell脚本export变量只限脚本内么_shell脚本调用oracle存储过程shell脚本中export命令未生效,原因详解问题:我有一个脚本,脚本中有如下一条语句exportfdu=“dufan”用sh运行脚本后,在当前shell利用命令env查看环境变量,但是却没有fdu变量,难道是因为我的export语句没有生效?解决结果:脚本中的export一定是生效的利用source执行脚本,在当前shell即可查看到fdu环境变量。这个问题涉及了三个知识点:变量(环境变量、自定义变量)父进程与子进程脚本的执行方式什么是变量?变量的分类?1.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

shell脚本中export命令未生效,原因详解

问题:我有一个脚本,脚本中有如下一条语句

export fdu=“dufan”

sh运行脚本后,在当前shell利用命令env查看环境变量,但是却没有fdu变量,难道是因为我的export语句没有生效?

解决结果

  1. 脚本中的export一定是生效的
  2. 利用source执行脚本,在当前shell即可查看到fdu环境变量。


这个问题涉及了三个知识点:

  • 变量(环境变量、自定义变量)
  • 父进程与子进程
  • 脚本的执行方式

什么是变量?变量的分类?

1. 环境变量

全局变量,可被子进程继承

2. 自定义变量

局部变量,不可被子进程继承

环境变量与自定变量的区别?

  • 环境变量与自定义变量的区别:该变量是否会被子进程所继续引用

    拓展

    • 什么是父进程?什么是子进程?

    • 子进程仅继承父进程的环境变量,子进程不会继承父进程的自定义变量

      可使用如下命令将自定义变量转换为环境变量:

      export 变量名称

    • 为什么父进程的环境变量数据可被子进程引用?

      1. 启动一个shell,os会分配一个记忆块给shell使用,此内存内的变量可让子进程取用
      2. 若父进程利用export功能,可以让自定义变量的内容写到上述的记忆块中
      3. 当加载另一个shell(子进程),子shell可以将父shell的环境变量所在的记忆块导入自己的环境变量块中

变量显示命令

  • 显示环境变量
    1. env
    2. export
  • 显示环境变量+自定义变量
    1. set

source、sh、./ 命令执行的区别

​ 用户登录到Linux系统后,系统将启动一个用户shell。在这个shell中,可以使用shell命令或声明变量,也可以创建并运行shell脚本程序。运行shell脚本程序时,系统将创建一个子shell。此时,系统中将有两个shell,一个是登录时系统启动的shell,另一个是系统为运行脚本程序创建的shell。当一个脚本程序运行完毕,它的脚本shell将终止,可以返回到执行该脚本之前的shell。从这种意义上来说,用户可以有许多 shell,每个shell都是由某个shell(称为父shell)派生的。
​ 在子 shell中定义的变量只在该子shell内有效。如果在一个shell脚本程序中定义了一个变量,当该脚本程序运行时,这个定义的变量只是该脚本程序内的一个局部变量,其他的shell不能引用它,要使某个变量的值可以在其他shell(子shell)中被使用,可以使用export命令对已定义的变量进行输出。 export命令将使系统在创建每一个新的shell时定义这个变量的一个拷贝。这个过程称之为变量输出。

​ source某脚本时,是在当前shell中执行,并未创建子进程(子shell)。

​ sh某脚本或./某脚本时,会创建子shell,在子进程中进行脚本的执行。

​ ./要求该用户对执行的脚本有执行权限,sh无要求。



知道上述几个知识点后,可以用一段话解释原因

​ export命令可以使自定义变量转换为环境变量,环境变量(全局变量)可被子进程继承,自定义变量(局部变量)不可以被子进程继承。sh执行脚本时,linux将创建子shell进程进行脚本执行,脚本执行结束后,在当前shell(父进程)必然无法查看已经消失的子进程的环境变量。而soure执行脚本,linux将在当前shell进程进行脚本执行,脚本执行结束后,环境变量生效。



实践验证

  • export功能验证

    [root@vm fdu]# set | grep fdu_val
    fdu_val=haha
    [root@vm fdu]# env | grep fdu_val
    [root@vm fdu]# 
    [root@vm fdu]# export fdu_val
    [root@vm fdu]# 
    [root@vm fdu]# env | grep fdu_val
    fdu_val=haha
    [root@vm fdu]# set | grep fdu_val
    fdu_val=haha
    [root@vm fdu]# 
    

    可以看到export命令将fdu_val自定义变量转换为了环境变量

  • 脚本执行方式对export的影响验证

    fdu_test.sh脚本如下:

    #####################################################
    ###export命令测试
    #环境变量
    export fdu_env_val="env_val"
    
    • source执行脚本
    [root@vm fdu]# env | grep fdu_env_val
    fdu_env_val=env_val
    [root@vm fdu]# set | grep fdu_env_val
    fdu_env_val=env_val
    [root@vm fdu]# /bin/bash
    [root@vm fdu]# env | grep fdu_env_val
    fdu_env_val=env_val
    [root@vm fdu]# set | grep fdu_env_val
    fdu_env_val=env_val
    [root@vm fdu]#```
    

    可以看到:source执行脚本,当前shell生效,子shell同样生效

    • sh执行脚本
    [root@vm fdu]# env | grep fdu_env_val
    [root@vm fdu]# set | grep fdu_env_val
    [root@vm fdu]# 
    [root@vm fdu]# /bin/bash
    [root@vm fdu]# export fdu_env_val="heihei"
    [root@vm fdu]# env | grep fdu_env_val
    fdu_env_val=heihei
    [root@vm fdu]# set | grep fdu_env_val
    fdu_env_val=heihei
    [root@vm fdu]# exit
    exit
    [root@vm fdu]# set | grep fdu_env_val
    [root@vm fdu]# env | grep fdu_env_val
    [root@vm fdu]# 
    

    可以看到:sh执行脚本,当前shell无效,/bin/bash进入子shell模拟sh执行脚本,发现子shell生效,退出子shell,回到父shell(当前shell),环境变量设置未生效

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196559.html原文链接:https://javaforall.net

(0)
上一篇 2025年9月24日 下午4:22
下一篇 2025年9月24日 下午5:01


相关推荐

  • Django(13)django时区问题

    Django(13)django时区问题前言我们都知道时区,标准时区是UTC时区,django默认使用的就是UTC时区,所以我们存储在数据库中的时间是UTC的时间,但是当我们做的网站只面向国内用户,或者只是提供内部平台使用,我们希望存储在

    2022年7月29日
    11
  • activity生命周期有几种状态_activity生命周期七种方法

    activity生命周期有几种状态_activity生命周期七种方法activity生命周期(这篇足够了)摘要做安卓开发已经4年多了,所接触的知识点也比较零散,在这里记录一下android方面的知识点,方便自己以后复习,有什么不足的,以及错误的欢迎拍砖。activityactivity从开始到结束的四个状态。activity的生命周期。activity的进程优先级。activity的四个状态关于activity的…

    2022年8月16日
    6
  • FFM原理理解与应用

    FFM原理理解与应用本文参考了美团团队的介绍文章。http://tech.meituan.com/deep-understanding-of-ffm-principles-and-practices.html以及http://blog.csdn.net/zc02051126/article/details/54614230FM和FFM模型是最近几年提出的模型,凭借其在数据量比较大并且特征稀疏的情况下,…

    2022年4月30日
    57
  • SpringBoot2 缓存之王caffeine

    SpringBoot2 缓存之王caffeinedependency groupId com github ben manes caffeine groupId artifactId caffeine artifactId version 2 9 0 version dependency 顺便写了个工具类配合 SpringBoot 使用 p

    2026年3月20日
    2
  • linux命令行怎么结束进程,linux结束进程命令「建议收藏」

    linux命令行怎么结束进程,linux结束进程命令「建议收藏」linux下进程的开启与结束都可以通过命令来控制,下面由学习啦小编为大家整理了linux下结束进程命令的相关知识,希望对大家有所帮助。linux结束进程命令1.killkill[信号代码]根据PID向进程发送信号,常用来结束进程,默认信号为-9信号代码,可取值如下:-l[信号数字]显示、翻译信号代码-9,-KILL发送kill信号退出-6,-ABRT发送abort信号…

    2025年6月22日
    5
  • 线程池拒绝策略详解[通俗易懂]

    线程池拒绝策略详解[通俗易懂]线程池拒绝策略详解JDK中已经预设了4种线程池拒绝策略,下面结合场景详细聊聊这些策略的使用场景,以及我们还能扩展哪些拒绝策略。池化设计思想池话设计应该不是一个新名词。我们常见的如java线程池、jdbc连接池、redis连接池等就是这类设计的代表实现。这种设计会初始预设资源,解决的问题就是抵消每次获取资源的消耗,如创建线程的开销,获取远程连接的开销等。就好比你去食堂打饭,打饭的大妈会先…

    2022年6月25日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号