导出新的环境参数而不输出到终端

导出新的环境参数而不输出到终端

我正在尝试运行一个脚本,但 bash export 输出了我不想要的文本,因为它破坏了输出。我需要运行一个脚本来提取一些信息,然后将其插入到下一个命令环境中,这有点像获取 awscli 的 AWS 机密并透明地将它们传递到 aws 环境中。我得到的结果不一致,我不确定为什么

$ ./bin/aws-creds mock
AWS_ACCESS_KEY_ID=mock1234
AWS_SECRET_ACCESS_KEY=mock1234
AWS_CREDS=success

$ ddt aws-creds mock
AWS_ACCESS_KEY_ID=mock1234
AWS_SECRET_ACCESS_KEY=mock1234
AWS_CREDS=success

两者的输出相同,这很好,所以让我们尝试运行它们并在输出上使用导出

$ export $(./bin/aws-creds mock)
$ export $(ddt aws-creds mock)
AWS_ACCESS_KEY_ID=mock1234
AWS_SECRET_ACCESS_KEY=mock1234
AWS_CREDS=success
declare -x .... a bunch of extra things from my environment

等一下?当使用子 shell $(...) 将这两个命令放入导出时,它们似乎执行不同的操作,这就是我想要修复的问题。我希望像第一个 ./bin 脚本一样,没有输出,但所有新参数都插入到 shell 环境中。似乎我编写的脚本“ddt”由于某种原因无法以相同的方式工作。

有人可以解释原因并提出一些解决方法吗?

答案1

[扩展自评论:] 该ddt命令将其输出发送到标准错误 (stderr) 而不是标准输出 (stdout),并且$( )仅捕获 stdout。 基本上有两种方法可以解决这个问题:

  1. 更好的选择是修复它ddt,以便将变量值发送到 stdout 而不是 stderr。
  2. 如果这不可能,您可以在命令2>&1后添加ddt,将其 stderr 重定向到 stdout(并允许$( )捕获它)。但这样做的风险是,如果ddt打印任何实际错误,它将继续尝试export这些消息,结果不可预测(并且可能是不理想的)。

查看问题Stackoverflow 上的“输出未在 bash 变量中捕获”

相关内容