我正在尝试运行一个脚本,但 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。 基本上有两种方法可以解决这个问题:
- 更好的选择是修复它
ddt
,以便将变量值发送到 stdout 而不是 stderr。 - 如果这不可能,您可以在命令
2>&1
后添加ddt
,将其 stderr 重定向到 stdout(并允许$( )
捕获它)。但这样做的风险是,如果ddt
打印任何实际错误,它将继续尝试export
这些消息,结果不可预测(并且可能是不理想的)。