如何将docker-compose.yml转换为Django的Dockerrun.aws.json [英] How to translate docker-compose.yml to Dockerrun.aws.json for Django
问题描述
我正在按照 https://docs.docker.com/compose/django/以运行基本的dockerized django应用程序.我可以在本地运行它,而不会出现问题,但是我无法使用Elastic Beanstalk将其部署到AWS.在阅读此处后,我认为我需要翻译docker-将compose.yml插入Dockerrun.aws.json以使其正常工作.
I am following the instructions at https://docs.docker.com/compose/django/ to get a basic dockerized django app going. I am able to run it locally without a problem but I am having trouble to deploy it to AWS using Elastic Beanstalk. After reading here, I figured that I need to translate docker-compose.yml into Dockerrun.aws.json for it to work.
原始docker-compose.yml是
The original docker-compose.yml is
version: '2'
services:
db:
image: postgres
web:
build: .
command: python manage.py runserver 0.0.0.0:8000
volumes:
- .:/code
ports:
- "8000:8000"
depends_on:
- db
这是我到目前为止翻译的内容
and here is what I translated so far
{
"AWSEBDockerrunVersion": 2,
"volumes": [
{
"name": "db"
},
{
"name": "web"
}
],
"containerDefinitions": [
{
"name": "db",
"image": "postgres",
"essential": true,
"memory": 256,
"mountPoints": [
{
"sourceVolume": "db"
"containerPath": "/var/app/current/db"
}
]
},
{
"name": "web",
"image": "web",
"essential": true,
"memory": 256,
"mountPoints": [
{
"sourceVolume": "web"
"containerPath": "/var/app/current/web"
}
],
"portMappings": [
{
"hostPort": 8000,
"containerPort": 8000
}
],
"links": [
"db"
],
"command": "python manage.py runserver 0.0.0.0:8000"
}
]
}
但是它不起作用.我在做什么错了?
but it's not working. What am I doing wrong?
推荐答案
我正在努力获取Dockerrun
格式的详细信息.查看容器转换:转换docker-compose,ECS和Marathon配置" ...救生员.这是您的示例输出的结果:
I was struggling to get the ins and outs of the Dockerrun
format. Check out Container Transform: "Transforms docker-compose, ECS, and Marathon configurations"... it's a life-saver. Here is what it outputs for your example:
{
"containerDefinitions": [
{
"essential": true,
"image": "postgres",
"name": "db"
},
{
"command": [
"python",
"manage.py",
"runserver",
"0.0.0.0:8000"
],
"essential": true,
"mountPoints": [
{
"containerPath": "/code",
"sourceVolume": "_"
}
],
"name": "web",
"portMappings": [
{
"containerPort": 8000,
"hostPort": 8000
}
]
}
],
"family": "",
"volumes": [
{
"host": {
"sourcePath": "."
},
"name": "_"
}
]
}
Container web is missing required parameter "image".
Container web is missing required parameter "memory".
Container db is missing required parameter "memory".
也就是说,在这种新格式下,您必须告诉它分配每个容器多少内存.另外,您需要提供图像-没有构建选项.如评论中所述,您想要构建并推送到DockerHub或ECR,然后为其指定位置:例如Dockerhub上的[org name]/[repo]:latest
或ECR的URL.但是container-transform
为您做了mountPoints
和volumes
-太神奇了.
That is, in this new format, you must tell it how much memory to allot each container. Also, you need to provide an image - there is no option to build. As is mentioned in the comments, you want to build and push to DockerHub or ECR, then give it that location: eg [org name]/[repo]:latest
on Dockerhub, or the URL for ECR. But container-transform
does the mountPoints
and volumes
for you - it's amazing.
这篇关于如何将docker-compose.yml转换为Django的Dockerrun.aws.json的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!