Teraz, kilka miesięcy później, jest to możliwe przy użyciu typu środowiska Multicontainer Docker:http://docs.aws.amazon.com/elasticbeanstalk/latest/dg/create_deploy_docker_ecs.html .
Oto dowód koncepcji Dockerrun.aws.json, którego jeszcze nie używałem w produkcji:
{
"AWSEBDockerrunVersion": 2,
"volumes": [
{
"name": "mongo-app",
"host": {
"sourcePath": "/var/app/current/mongo-app"
}
}
],
"containerDefinitions": [
{
"name": "mongo-app",
"image": "mongo",
"essential": true,
"memory": 6000,
"command": ["mongod","--storageEngine=wiredTiger","--logpath=/var/log/mongodb/mongo.log"],
"portMappings": [
{
"hostPort": 27017,
"containerPort": 27017
}
],
"mountPoints": [
{
"sourceVolume": "mongo-app",
"containerPath": "/data/db"
},
{
"sourceVolume": "awseb-logs-mongo-app",
"containerPath": "/var/log/mongodb"
}
]
}
]
}
To podejście wymaga, aby typ środowiska był ustawiony na Multicontainer Docker i aby grupa zabezpieczeń była dołączona do środowiska Elastic Beanstalk, które umożliwia dostęp do portu 27017 z klientów bazy danych.