Dockerfile में EXPOSE का उपयोग क्यों करें - चूंकि आप सभी पोर्ट्स वैसे भी बांध सकते हैं


23

मैं कर सकते हैं docker run -p 3000:3000 image बिना EXPOSE कंटेनर में है कि बंदरगाह ing (नीचे देखें)। अगर यह सच है, तो डॉकफाइल में एक्सपोजर डालने की जहमत क्यों? क्या यह केवल छवि उपयोगकर्ताओं के लिए संचार के लिए है? क्योंकि मैं एक्सपोज़ पोर्ट के लिए एक कार्यात्मक कारण नहीं जानता, अगर वे सभी बांधने योग्य रास्ते हैं।


इस चरण में मुझे एक कंटेनर में एक बंदरगाह से बांधने के बारे में दिखाया गया है, इस तथ्य के बावजूद कि यह EXPOSEd नहीं है

$ cat Dockerfile
FROM alpine
RUN apk add nodejs npm vim
COPY webserver /webserver
CMD [ "node", "/webserver/index.js" ]


$ docker build .
Sending build context to Docker daemon  1.931MB
Step 1/4 : FROM alpine
 ---> 11cd0b38bc3c
Step 2/4 : RUN apk add nodejs npm vim
 ---> Using cache
 ---> 4270f8bdb201
Step 3/4 : COPY webserver /webserver
 ---> Using cache
 ---> 67f4cda61ff0
Step 4/4 : CMD [ "node", "/webserver/index.js" ]
 ---> Using cache
 ---> 1df8f9024b85
Successfully built 1df8f9024b85


$ curl localhost:4400
curl: (7) Failed to connect to localhost port 4400: Connection refused


$ docker run -d -p 4400:3000 1df8f9024b85
7d0e6c56f8ad8827fe72830a30c1aac96821104b8ea111291ca39e6536aad8fd


$ curl localhost:4400
Hello World!


$

जवाबों:


29

डॉकर का एक्सपोज दस्तावेज इस विशिष्ट बिंदु को संबोधित करता है:

EXPOSEअनुदेश वास्तव में बंदरगाह प्रकाशित नहीं करता है। यह छवि बनाने वाले व्यक्ति और कंटेनर चलाने वाले व्यक्ति के बीच एक प्रकार के प्रलेखन के रूप में कार्य करता है, जिसके बारे में बंदरगाहों को प्रकाशित करने का इरादा है। कंटेनर को चलाने के दौरान वास्तव में पोर्ट को प्रकाशित करने के लिए, -pध्वज का उपयोग docker runप्रकाशित करने के लिए और एक या अधिक बंदरगाहों को मैप करने के लिए, या -Pसभी उजागर बंदरगाहों को प्रकाशित करने के लिए और उन्हें उच्च-क्रम वाले पोर्ट पर मैप करने के लिए ध्वज का उपयोग करें।

अंतिम वाक्य पर ध्यान दें, यदि आप कई पोर्ट को उजागर करते हैं तो कमांड लाइन पर -Pकई -pको सेट करने से बचने के लिए उपयोगी हो जाता है ।


"प्रलेखन" छवि मेटाडेटा के रूप में है। -Pझंडे के लिए उपयोगी होने के अलावा , अन्य उपयोगिताओं इस मेटाडेटा के लिए चल रहे कंटेनरों को क्वेरी कर सकती हैं, जो प्रॉक्सी में उपयोगी है जो इन उजागर बंदरगाहों का उपयोग करते हुए उनके चूक के रूप में गतिशील रूप से अपने अग्रेषण नियमों को अपडेट करते हैं।
बीएमच

@ बिल्कुल, मुझे लगा कि यह एक बाहरी जानकारी थी जो अभी तक ओपी के लिए उपयोगी नहीं है, लेकिन इसे संपादित करने के लिए स्वतंत्र महसूस करें।
तेंसिबाई

EXPOSE प्रलेखन है
井上 智 '

4

यह स्वचालन के लिए किया जाता है। आपके पास एक सार्वभौमिक आदेश हो सकता है जो docker run -Pएक कंटेनर को शुरू करने के लिए चलता है और डॉकफेरफाइल खुद को निर्दिष्ट करने के लिए उपयोग किया जाता है कि कौन सा कंटेनर किस बंदरगाह को उजागर करता है। यदि आप एक पाइपलाइन के माध्यम से दर्जनों या सैकड़ों कंटेनरों का निर्माण कर रहे हैं, तो यह काफी उपयोगी है। एक चरण से दूसरे चरण में पाइप लाइन के माध्यम से कंटेनर के साथ डॉकरीफाइल में शामिल नहीं होने वाले बाहरी विवरणों को पास करना काफी कठिन है।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.