एक एकल नोड को पुन: प्रारंभ करने के लिए अन्य उत्तर, लक्ष्य पर हैं docker-compose restart worker
। यह उस कंटेनर को उछाल देगा, लेकिन इसमें कोई बदलाव शामिल नहीं है, भले ही आपने इसे अलग से बनाया हो। आप मैन्युअल रूप से कर सकते हैं stop
, rm
, create
, और start
, लेकिन वहाँ बहुत आसान तरीके हैं।
यदि आपने अपना कोड अपडेट कर दिया है, तो आप एक ही चरण में निर्माण और पुनः लोड कर सकते हैं:
docker-compose up --detach --build
यह किसी भी परिवर्तित कोड से सबसे पहले आपकी छवियों का पुनर्निर्माण करेगा, जो कि कैश का पुन: उपयोग किए जाने के बाद से कोई बदलाव नहीं होने पर तेजी से होता है। और फिर यह केवल बदले हुए कंटेनरों की जगह लेता है। यदि आपकी डाउनलोड की गई छवियां बासी हैं, तो आप उपरोक्त आदेश को पूर्ववर्ती कर सकते हैं:
docker-compose pull
किसी भी बदली हुई इमेज को डाउनलोड करने के लिए (जब तक आप up
ऊपर की तरह कमांड नहीं चलाते हैं तब तक कंटेनर को फिर से शुरू नहीं किया जाएगा )। प्रारंभिक रोकना अनावश्यक है।
और केवल एक ही सेवा के लिए ऐसा करने के लिए, उन सेवाओं के साथ अप या पुल कमांड का पालन करें जिन्हें आप निर्दिष्ट करना चाहते हैं, जैसे:
docker-compose up --detach --build worker
यहां पहले विकल्प का एक त्वरित उदाहरण है, डॉकरीफाइल को कोड के अंत में अक्सर बदलते हिस्सों को पास रखने के लिए संरचित किया जाता है। वास्तव में आवश्यकताओं को अलग से खींच लिया जाता है pip install
क्योंकि उस फ़ाइल में शायद ही कभी बदलाव होता है। और जब से नगनेक्स और रेडिस कंटेनर अप-टू-डेट थे, तब तक उन्हें फिर से शुरू नहीं किया गया था। पूरी प्रक्रिया के लिए कुल समय 6 सेकंड से कम था:
$ time docker-compose -f docker-compose.nginx-proxy.yml up --detach --build
Building counter
Step 1 : FROM python:2.7-alpine
---> fc479af56697
Step 2 : WORKDIR /app
---> Using cache
---> d04d0d6d98f1
Step 3 : ADD requirements.txt /app/requirements.txt
---> Using cache
---> 9c4e311f3f0c
Step 4 : RUN pip install -r requirements.txt
---> Using cache
---> 85b878795479
Step 5 : ADD . /app
---> 63e3d4e6b539
Removing intermediate container 9af53c35d8fe
Step 6 : EXPOSE 80
---> Running in a5b3d3f80cd4
---> 4ce3750610a9
Removing intermediate container a5b3d3f80cd4
Step 7 : CMD gunicorn app:app -b 0.0.0.0:80 --log-file - --access-logfile - --workers 4 --keep-alive 0
---> Running in 0d69957bda4c
---> d41ff1635cb7
Removing intermediate container 0d69957bda4c
Successfully built d41ff1635cb7
counter_nginx_1 is up-to-date
counter_redis_1 is up-to-date
Recreating counter_counter_1
real 0m5.959s
user 0m0.508s
sys 0m0.076s