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': []
}]
}]
ここで何が欠けていますか?