我有一个使用docker-compose在单个服务器上运行的React / Node.js应用程序。我正在尝试为我的反应应用程序实现0停机时间部署。现在的过程,做一个webpack构建(替换我的dist文件夹中的文件),然后停靠并停泊。整个过程大约需要2-3分钟。
我意识到使用docker-compose我可以向上/向下扩展我的容器但是我不知道如何只将我的代码推送到其中一个,重建webpack并且npm重新启动它然后杀死其他容器。我真的不想使用Kubernetes / Swarm或Openshift,因为它有点矫枉过正。我想知道是否还有其他人取得了类似的成就。
我的docker-compose看起来像这样:
node:
build:
context: ./env/docker/node
args:
- PROJECT_ROOT=/var/www/app
image: react_app:rapp_node
command: "npm run prod"
expose:
- "3333"
networks:
- react-net
volumes_from:
- volumes_source
tty: false
nginx:
env_file:
- ".env"
build:
context: ./env/docker/nginx
volumes_from:
- volumes_source
volumes:
- ./env/data/logs/nginx/:/var/log/nginx
- ./env/docker/nginx/sites/node.template:/etc/nginx/node.template
networks:
- react-net
- nginx-proxy
environment:
NGINX_HOST: ${NGINX_HOST}
VIRTUAL_HOST: ${NGINX_VIRTUAL_HOST}
LETSENCRYPT_HOST: ${NGINX_VIRTUAL_HOST}
ESC: $$
links:
- node:node
command: /bin/sh -c "envsubst < /etc/nginx/node.template > /etc/nginx/sites-available/node.conf && nginx -g 'daemon off;'"
volumes_source:
image: tianon/true
volumes:
- ./app:/var/www/app
我的nginx是这样的:
server {
server_name www.${NGINX_HOST};
return 301 ${ESC}scheme://${NGINX_HOST}${ESC}request_uri;
}
server {
listen 80;
server_name ${NGINX_HOST};
root /var/www/app;
location / {
proxy_pass http://node:3333;
proxy_http_version 1.1;
proxy_set_header Upgrade ${ESC}http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host ${ESC}host;
proxy_cache_bypass ${ESC}http_upgrade;
}
}
答案 0 :(得分:0)
如何刷新容器的更快方法是
docker-compose restart node
因为如果你执行docker-compose down
,它将关闭所有服务,删除已配置的网络。
如果您有缩放服务,可以尝试使用
重新启动它docker restart foldername_node_2
你可能有0停机时间,但是nginx配置不够,因为它会随机选择node
机器,所以你必须实现一些备份服务器