AWS CLI S3 CP --recursive 函数在控制台中有效,但在 .sh 文件中无效

AWS CLI S3 CP --recursive function works in console but not in .sh file

我在 .sh 文件中有以下行:

aws s3 cp s3://bucket/folder/ /home/ec2-user/ --recursive

当我在控制台中 运行 这一行时,它 运行 正常并按预期完成。当我在一个.sh文件中运行这一行时,returns行出现以下错误。

Unknown options: --recursive

这是我的完整 .sh 脚本。

echo "Test"
aws s3 cp s3://bucket/folder/ /home/ec2-user/ --recursive
echo "Test"
python /home/ec2-user/Run.py

如果我手动添加 Run.py 文件(没有根据需要从 S3 复制它)和 运行 脚本,我会得到以下输出。

Test

Unknown options: --recursive
Test
Hello World

如果我从 Linux 环境中删除预期由 S3 传输的文件并依赖 AWS S3 命令,我将得到以下输出:

Test

Unknown options: --recursive
Test
python: can't open file '/home/ec2-user/Run.py': [Errno 2] No such file or directory

请注意,可以在指定的 S3 位置内传输多个文件。 运行从控制台执行 AWS 命令​​时,所有这些文件都按预期传输。

我最初认为这是行结束错误,因为我正在从 Windows 复制 .sh 文件。我已确保我的行结尾正常工作,并且我们按预期在脚本的其余部分 运行ning 中看到了这一点。因此,这个问题似乎与实际的 AWS 命令​​无关。如果我从通话中删除 --recursive,它将成功传输单个文件。

关于为什么 --recursive 选项在控制台中有效但在 .sh 文件中无效的任何想法?

P.s.

$ aws --version
aws-cli/2.1.15 Python/3.7.3 Linux/4.14.209-160.339.amzn2.x86_64 exe/x86_64.amzn.2 prompt/off

我认为这与选项的位置有关,或者您有指向旧版本的 AWS CLI 路径,因为 后来添加了递归选项。对我来说,它在 shell 脚本和控制台中都有效。

aws s3 cp --recursive  s3://bucket/folder/ /home/ec2-user/ 

$ aws --version
aws-cli/2.1.6 Python/3.7.4 Darwin/20.2.0 exe/x86_64 prompt/off

尝试打印 shell 脚本中的版本。

cp --recursive 方法列出源路径并复制(覆盖)所有到目标路径。

Plus 而不是递归使用 sync.sync 递归地将新的和更新的文件从源目录复制到目标。如果文件夹包含一个或多个文件,则仅在目的地创建文件夹。

aws s3 sync 3://bucket/folder/ /home/ec2-user/

sync 方法首先列出源路径和目标路径,并仅复制差异(名称、大小等)。