我有一个React/Node.js应用程序运行在一个服务器上,使用的是docker-组合。我试图实现我的反应应用程序的0停机时间部署。现在处理,做webpack构建(替换我的dist文件夹中的文件),然后停靠和对接。整个过程大约需要2-3分钟。
我意识到,与对接-合成,我可以缩放我的容器上/下,但我不知道如何只把我的代码,其中一个,重建webpack和npm重新启动它,然后杀死其他容器。我真的不想使用Kubernetes/群或Openshift,因为这有点过分。我想知道是否还有其他人取得了类似的成就。
我的船坞组合看起来是这样的:
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;
}
}发布于 2018-03-14 06:40:38
如何刷新容器的更快方式是
docker-compose restart node因为如果您使用docker-compose down,它将关闭所有服务,删除配置好的网络。
如果您已经缩放了服务,您可以尝试用
docker restart foldername_node_2您可以有0停机时间,但是nginx配置还不够,因为它会随机选择node机器,因此您必须实现一些备份服务器。
https://stackoverflow.com/questions/49263335
复制相似问题