aws ec2 request-spot-instances CLI问题

时间:2013-12-03 18:05:19

标签: amazon-web-services amazon-ec2

尝试在一个简单的脚本中启动几个spot实例,并且AWS文档中提供的语法和aws ec2 request-spot-instances帮助输出以JAVA或JSON语法列出。如何从shell脚本中输入JSON语法下的参数?

aws --version

aws-cli / 1.2.6 Python / 2.6.5 Linux / 2.6.21.7-2.fc8xen

aws ec2 request-spot-instances帮助   - 在“启动规范”的开头,它列出了JSON语法

- 启动规范(结构)            指定其他启动实例信息。

   JSON Syntax:

       {
         "ImageId": "string",
         "KeyName": "string",
         }, ....
         "EbsOptimized": true|false,
         "SecurityGroupIds": ["string", ...],
         "SecurityGroups": ["string", ...]
       }

我尝试了以下所有可能的组合,添加&移动括号,报价,更改选项等等都无济于事。下面的变量$ launch的正确格式是什么?其他命令变体 - “ec2-request-spot-instances”在我的环境中不起作用,如果我尝试用-p替换--spot-price,它也不起作用。

#!/bin/bash
launch="{"ImageId":"ami-a999999","InstanceType":"c1.medium"} "SecurityGroups":"launch-wizard-6""

echo $launch

aws ec2 request-spot-instances --spot-price 0.01 --instance-count 1 --type  c1.small --launch-specification $launch

这提供了结果: 未知选项:SecurityGroups:launch-wizard-6

替换安全组编号具有相同的结果。

aws ec2 describe-instances和aws ec2 start-instance一样工作正常,因此环境和帐户信息设置正确,但我需要利用现货定价。

事实上,此用户文档中未列出任何内容:http://docs.aws.amazon.com/AWSEC2/latest/CommandLineReference/ApiReference-cmd-RequestSpotInstances.html

谢谢,

3 个答案:

答案 0 :(得分:3)

我知道这是一个老问题,但万一有人碰到它。我最近在CLI上遇到了同样的问题。要求所有参数在request-spot-instances

中正常工作非常困难


#!/bin/bash
AWS_DEFAULT_OUTPUT="text"
UserData=$(base64 < userdata-current)
region="us-west-2"
price="0.03"
zone="us-west-2c"

aws ec2 request-spot-instances  --region $region --spot-price $price  --launch-specification "{ \"KeyName\": \"YourKey\", \"ImageId\": \"ami-3d50120d\" , \"UserData\": \"$UserData\", \"InstanceType\": \"r3.large\" , \"Placement\": {\"AvailabilityZone\": \"$zone\"}, \"IamInstanceProfile\": {\"Arn\": \"arn:aws:iam::YourAccount:YourProfile\"},   \"SecurityGroupIds\": [\"YourSecurityGroupId\"],\"SubnetId\": \"YourSubnectId\" }"

基本上我要做的就是将我的用户数据放在外部文件中,将其加载到UserData变量中,然后在命令行上传递它。尝试在命令行上获取所有内容或使用ec2-request-spot-instances的外部文件只是保持失败。请注意,其他命令工作正常,因此这是特定于ec2-request-spot-instances。

我详细介绍了我最终做的事情here

答案 1 :(得分:0)

这里的第一个问题是引用和格式化:

$ launch="{"ImageId":"ami-a999999","InstanceType":"c1.medium"} "SecurityGroups":"launch-wizard-6""

这不会生成有效的JSON,因为您从帮助文件中复制的块包含来自嵌套对象的虚假结束括号,您没有包含,结束括号丢失,未转义的双引号是消失。

但是我们并没有真正达到json实际验证的程度,因为在最后一个大括号之后的那个空间,cli假设SecurityGroups和launch-wizard-6是参数之后的更多命令行选项到--launch-specification

$ echo $launch
{ImageId:ami-a999999,InstanceType:c1.medium} SecurityGroups:launch-wizard-6

这可能不是你所期望的......所以我们将修改引用,使其在json有效后看起来像一个长参数:

从仅生成有效的json 结构(不一定是内容)的角度来看,您最有可能尝试发送的数据实际上看起来像这样,基于文档:

{"ImageId":"ami-a999999","InstanceType":"c1.medium","SecurityGroups":["launch-wizard-6"]}

检查结构有效的JSON,here

修复支撑,逗号和括号,CLI停止抛出该错误,使用以下格式:

$ launch='{"ImageId":"ami-a999999","InstanceType":"c1.medium","SecurityGroups":["launch-wizard-6"]}'
$ echo $launch
{"ImageId":"ami-a999999","InstanceType":"c1.medium","SecurityGroups":["launch-wizard-6"]}

这并不是说由于其他不正确或缺失的原因,API可能不会随后拒绝该请求,但您实际上从未实际向API发送任何内容;这是在命令行工具中失败的本地验证。

答案 2 :(得分:0)

在这种情况下你必须使用一个列表:

"SecurityGroups": ["string", ...]

所以

"SecurityGroups":"launch-wizard-6"

成为

"SecurityGroups":["launch-wizard-6"]

无论如何,我现在正在处理CLI,我发现使用外部JSON更有用

以下是使用Python的示例:

myJson="file:///Users/xxx/Documents/Python/xxxxx/spotInstanceInformation.json"
x= subprocess.check_output(["/usr/local/bin/aws ec2 request-spot-instances --spot-price  0.2 --launch-specification "+myJson],shell=True)
print x

输出是:

"SpotInstanceRequests": [
 {
"Status": {
            "UpdateTime": "2013-12-09T02:41:41.000Z", 
            "Code": "pending-evaluation", 
            "Message": "Your Spot request has been submitted for review, and is pending evaluation."
etc etc ....

Doc就在这里:http://docs.aws.amazon.com/cli/latest/reference/ec2/request-spot-instances.html

仅供参考 - 我正在追加file:///,因为我正在使用MAC。如果您使用Linux启动bash脚本,可以使用myJson =“/ path / to / file /”