使用RunTask命令时,我试图覆盖容器上的 CPU 和内存限制。我正在使用 Python SDK,boto3。
容器的默认 CPU 限制为 0(无限制),软内存限制为 1024。这一切都很好。
当我尝试将containerOverrides
列表传递给 RunTask 命令时,我没有收到错误,这些任务大部分都按预期运行。我还覆盖了容器运行的命令,并且有效 - 我可以看到任务正在运行,该命令已被覆盖,并且日志反映了这一点。
但是,CPU 和内存限制并未被覆盖。我通过查看 AWS 控制台并看到 cpu 和内存列为 0 和 1024 来检查这一点,但显示该命令已被覆盖。我还可以通过检查容器实例来确认内存不是所需的 2048,而必须是 1024 来做一些数学运算。
这是一些简化的代码:
import boto3
client = boto3.client('ecs')
overrides = {
"containerOverrides": [
{
"name": "runcommand",
"command": command_wrapper,
"cpu": 512,
"memory": 2048,
"memoryReservation": 2048
}
]
}
response = client.run_task(
cluster='mycluster',
taskDefinition='runcommand-qa',
overrides=overrides,
group='stackoverflow:run-command'
)
tasks
以及响应的部分:
'tasks': [{
'taskArn': 'arn:aws:ecs:us-east-1:12345667890:task/72f1a8ae-4f51-4717-acc6-fce3199a9e92',
'group': 'stackoverflow:run-command',
'attachments': [],
'overrides': {
'containerOverrides': [{
'memoryReservation': 2048,
'memory': 2048,
'command': ['sh', '-c', '. /app/bin/activate && ./manage.py help'],
'name': 'runcommand',
'cpu': 512
}]
},
'launchType': 'EC2',
'lastStatus': 'PENDING',
'containerInstanceArn': 'arn:aws:ecs:us-east-1:12345667890:container-instance/f0dd320e-b1de-413d-8e1c-c64b0799e473',
'createdAt': datetime.datetime(2018, 5, 25, 9, 4, 3, 46000, tzinfo = tzlocal()),
'version': 1,
'clusterArn': 'arn:aws:ecs:us-east-1:12345667890:cluster/runcommand-qa',
'memory': '2048',
'desiredStatus': 'RUNNING',
'taskDefinitionArn': 'arn:aws:ecs:us-east-1:12345667890:task-definition/runcommand-qa:127',
'cpu': '512',
'containers': [{
'containerArn': 'arn:aws:ecs:us-east-1:12345667890:container/80949a81-747f-4729-a9d4-922007448729',
'taskArn': 'arn:aws:ecs:us-east-1:12345667890:task/72f1a8ae-4f51-4717-acc6-fce3199a9e92',
'lastStatus': 'PENDING',
'name': 'runcommand',
'networkInterfaces': []
}]
}]
我在这里想念什么?