我正在尝试创建一个Docker Compose文件来为ReactJS项目构建我的本地开发和部署管道。
一些上下文:本地我在3000
端口启动服务器。对于部署,我导出静态伪像,在S3上部署它并使我的CloudFront文件无效。
我已经构建了一个包含节点和AWS CLI的Docker Image,我使用它作为我的基础FROM
Image。
Dockerfile
FROM a6kme/node-aws-cli:v1
WORKDIR /app
COPY package*.json /app/
RUN npm install
EXPOSE 3000
泊坞窗,compose.yml
version: '3'
volumes:
esnextwebjourney_node_modules:
services:
esnextwebjourney:
build: .
volumes:
- .:/app
- esnextwebjourney_node_modules:/app/node_modules
ports:
- 3000:3000
command: >
sh -c "npm run build && npm run start"
这是有效的,但每次我必须继续更新命令,以启动服务器npm run build && npm run start
或部署在s3和CloudFront,即npm run build && npm run export && npm run deploy
。
我的问题是 - 我可以创建一个像下面这样的docker-compose.yml文件,然后我可以调用docker-compose run start --build
或docker-compose run deploy --build
,这将同时满足我的目的。
version: '3'
volumes:
esnextwebjourney_node_modules:
services:
build:
build: .
volumes:
- .:/app
- esnextwebjourney_node_modules:/app/node_modules
command: npm run build
start:
depends_on:
- build
command: npm run start
ports:
- 3000:3000
export:
depends_on:
- build
command: npm run export
deploy:
depends_on:
- export
command: npm run deploy
您可以创建覆盖:
泊坞窗,compose.override.yml:
version: '3'
services:
esnextwebjourney:
command: "npm run build && npm run export && npm run deploy"
当你想导出时,你可以运行:docker-compose up -d --build当你只想部署时:docker-compose -f docker-compose.yml up -d --build
第二个版本忽略覆盖。
另一种解决方案是为命令使用环境变量。这样,您的docker-compose.yml始终保持不变,您只需在运行之前导出新的环境变量。您可以使用shell脚本自动执行此操作。
如果您创建命名卷并在所有服务之间共享它,那么您想要构建的内容也可能有效。但我更喜欢我的解决方案:)
我希望这适合你。