假设我有这样的脚本:

export.bash:

#! /usr/bin/env bash
export VAR="HELLO, VARIABLE"

当我执行脚本并试图访问$VAR时,我没有得到任何值!

echo $VAR

是否有一种方法通过执行export来访问$VAR。没有来源的Bash ?


当前回答

我有类似的问题调用ssh-agent -s在rsync的选项-e调用的脚本。

在脚本中,eval $(ssh-agent -s)不为下一次调用保留环境变量。

rsync -e 'source ssh-check-agent.sh -p 8022'不起作用,所以我做了一个变通方案。在脚本中,我在调用ssh-agent后将变量保存在一个临时文件中,如下:

echo "export SSH_AUTH_SOCK=$SSH_AUTH_SOCK;" > /tmp/ssh-check-agent.vars
echo "export SSH_AGENT_PID=$SSH_AGENT_PID;" >> /tmp/ssh-check-agent.vars

然后在调用rsync (backup.sh)的脚本中调用:

source /tmp/ssh-check-agent.vars

问题是调用rsync的脚本必须由source (source backup.sh)调用。

我知道这不是问题(我使用两次源),但如果有人在rsync上有类似的问题,我在这里放了。

其他回答

这个变通方法在其他地方也有暗示,但可能不是那么清楚:

在脚本中,设置变量后,启动一个新的shell,而不是返回。

我的用例是,我有许多打开的终端,在其中一些终端中,我想要一些变量的值,而在其他终端中,我想要其他值。

由于使用source可能更难记住,这种方法的一个小优点是,当您需要一段时间才能意识到您忘记使用source时,您必须从头开始。

(对我来说,使用源脚本更有意义,因为缺失的变量会立即被注意到。)

简单幼稚的方法有效:

脚本1:

回显"something" > /tmp/myvar

脚本2:

myvar=$(cat /tmp/myvar)

我发现了一个从文件中导出环境变量的有趣而简洁的方法:

在文件env.vars中:

foo=test

测试脚本:

eval `cat env.vars`
echo $foo         # => test
sh -c 'echo $foo' # =>

export eval `cat env.vars`
echo $foo         # => test
sh -c 'echo $foo' # => test

# a better one. "--" stops processing options,
# key=value list given as parameters
export -- `cat env.vars`
echo $foo         # => test
sh -c 'echo $foo' # => test

使用脚本文件导出环境变量

问题: 当您运行一个脚本时,它在子shell中执行,并在执行后返回到父shell。导出变量只适用于子shell,不能将子shell的变量导出回父shell。

解决方案: 从你的脚本文件调用一个子shell和你想要导出的变量,这将创建一个新的子shell和你导出的变量。

script.sh - - - >

bash -c 'export VAR=variable; exec bash'

:: ciph3r

我有类似的问题调用ssh-agent -s在rsync的选项-e调用的脚本。

在脚本中,eval $(ssh-agent -s)不为下一次调用保留环境变量。

rsync -e 'source ssh-check-agent.sh -p 8022'不起作用,所以我做了一个变通方案。在脚本中,我在调用ssh-agent后将变量保存在一个临时文件中,如下:

echo "export SSH_AUTH_SOCK=$SSH_AUTH_SOCK;" > /tmp/ssh-check-agent.vars
echo "export SSH_AGENT_PID=$SSH_AGENT_PID;" >> /tmp/ssh-check-agent.vars

然后在调用rsync (backup.sh)的脚本中调用:

source /tmp/ssh-check-agent.vars

问题是调用rsync的脚本必须由source (source backup.sh)调用。

我知道这不是问题(我使用两次源),但如果有人在rsync上有类似的问题,我在这里放了。