डॉकर कंपोज़ - मेमोरी लिमिट्स

Docker Compose Memory Limits



डॉकर कंपोज़ एक शक्तिशाली उपयोगिता है। यह आपके Dockerized एप्लिकेशन को परिनियोजित करते समय समय बचाता है और त्रुटियों को कम करता है। आम तौर पर, एक ही कंटेनर के अंदर से फ्रंटएंड, डेटाबेस सर्वर इत्यादि सहित पूरे स्टैक को चलाने के लिए यह एक अच्छा विचार नहीं है।

हम किसी एप्लिकेशन के विभिन्न वर्कलोड को संभालने के लिए अलग-अलग कंटेनरों को स्पिन करते हैं और हम इसे आसानी से करने के लिए डॉकर कंपोज़ का उपयोग करते हैं। प्रत्येक तार्किक रूप से भिन्न कार्यभार को भिन्न के रूप में सूचीबद्ध किया गया है सेवा . उदाहरण के लिए, आपके फ्रंटएंड http सर्वर को एक अपाचे या एक Nginx छवि को कंटेनर के रूप में चलाने वाली फ्रंटएंड सेवा के रूप में सूचीबद्ध किया जाएगा।







सभी सेवाओं, उनकी नेटवर्किंग आवश्यकताओं, भंडारण आवश्यकताओं आदि को docker-compose.yml फ़ाइल में निर्दिष्ट किया जा सकता है। हम यहां स्मृति उपयोग को निर्दिष्ट करने पर ध्यान केंद्रित करेंगे।



साथ चलने के लिए आपको अपने शस्त्रागार में निम्नलिखित टूल की आवश्यकता होगी:



  1. डॉकर की बुनियादी समझ
  2. विंडोज या मैक के लिए डॉकर या यदि आप Linux चला रहे हैं, लिनक्स के लिए डॉकरसीई
  3. डॉकर कंपोज़ बिनार y (Windows और Mac उपयोगकर्ताओं के पास यह पहले से ही स्थापित होगा)

हम अपनी docker-compose.yml फ़ाइलों के लिए संस्करण २.४ से चिपके रहेंगे क्योंकि यह संस्करण १७.१२ और डॉकर इंजन और उच्चतर संस्करण का समर्थन करता है। हम संस्करण 3 के साथ जा सकते थे जो अधिक हाल का है लेकिन यह पुराने मेमोरी लिमिटेशन सिंटैक्स का समर्थन नहीं करता है। यदि आप नए सिंटैक्स का उपयोग करने का प्रयास करते हैं, तो यह इसके बजाय डॉकर को झुंड मोड में उपयोग करने पर जोर देता है। इसलिए नियमित डॉकर उपयोगकर्ताओं के लिए मामले को सरल रखने के लिए मैं संस्करण 2.4 . पर टिका रहूंगा





अधिकांश कोड संस्करण 3 के लिए समान काम करेंगे, और जहां कोई अंतर होगा, मैं डॉकर झुंड उपयोगकर्ताओं के लिए नए सिंटैक्स का उल्लेख करूंगा।

नमूना आवेदन

आइए पहले सीएलआई और फिर एक साधारण docker-compose.yml का उपयोग करके पोर्ट 80 पर एक साधारण Nginx सेवा चलाने का प्रयास करें। अगले भाग में, हम इसकी स्मृति सीमाओं और उपयोग का पता लगाएंगे और यह देखने के लिए हमारे docker-compose.yml को संशोधित करेंगे कि कस्टम सीमाएं कैसे लगाई जाती हैं।



आइए Docker-CLI का उपयोग करके एक साधारण nginx सर्वर शुरू करें:

$ डॉकर रन -d --name my-nginx -p80:80nginx: नवीनतम

आप nginx सर्वर को काम करते हुए देख सकते हैं http://लोकलहोस्ट या lcoalhost बदलें

अपने डॉकर होस्ट के आईपी पते के साथ। यह कंटेनर संभावित रूप से आपके डॉकर होस्ट पर उपलब्ध संपूर्ण मेमोरी का उपयोग कर सकता है (हमारे मामले में यह लगभग 2GB है)। स्मृति उपयोग की जाँच करने के लिए, अन्य बातों के अलावा, हम कमांड का उपयोग कर सकते हैं:

$ docker आँकड़े my-nginx

कंटेनर आईडी नाम सीपीयू% एमईएम उपयोग / सीमा मेम% नेट I/O ब्लॉक I/O PIDS
6eb0091c0cf20.00% 2.133MiB / 1.934GiB0.11% 3.14kB / 2.13kB 0B / 0B2

कुल 1.934GiB में से MEM USAGE/LIMIT 2.133MiB है। आइए इस कंटेनर को हटा दें और docker-compose Scripts लिखना शुरू करें।

$ docker बंद करो my-nginx
$ docker rm my-nginx

समतुल्य ym फ़ाइल

यदि हम इन चरणों का पालन करते हैं तो ऊपर के रूप में सटीक कंटेनर बनाया जा सकता है:

$mkdir my-compose
$ सीडी माय-कंपोज़
$ vim docker-compose.yml

हम एक नई खाली निर्देशिका बनाते हैं और उसमें एक फ़ाइल docker-compose.yml बनाते हैं। जब हम इस निर्देशिका से docker-compose up चलाएंगे, तो यह इस विशिष्ट फ़ाइल की तलाश करेगा (बाकी सब कुछ अनदेखा कर रहा है) और तदनुसार हमारी तैनाती तैयार करेगा। इस .yml फ़ाइल के अंदर निम्नलिखित सामग्री जोड़ें।

संस्करण:'3'
सेवाएं:
मेरा-nginx:
छवि: nginx: नवीनतम
बंदरगाह:
-'80: 80'

$ docker-compose up -d

-d ध्वज जोड़ा जाता है ताकि नव निर्मित कंटेनर पृष्ठभूमि में चल सकें। अन्यथा, टर्मिनल खुद को कंटेनरों से जोड़ लेगा और उससे रिपोर्ट प्रिंट करना शुरू कर देगा। अब हम नव निर्मित कंटेनर के आँकड़े देख सकते हैं:

$ डोकर आँकड़े -सभी

कंटेनर आईडी नाम सीपीयू% एमईएम उपयोग/सीमा एमईएम% नेट I/O ब्लॉक I/O PIDS
5f8a1e2c08ac my-compose_my-nginx_10.00% 2.25MiB/1.934GiB0.11% 1.65kB/0B 7.35MB/0B2

आप देखेंगे कि पहले जैसा एक समान कंटेनर समान मेमोरी सीमा और यहां तक ​​कि उपयोग के साथ बनाया गया था। उसी निर्देशिका से जिसमें yml फ़ाइल है। बनाए गए ग्राहक ब्रिज नेटवर्क के साथ नव निर्मित कंटेनर को हटाने के लिए निम्न आदेश चलाएँ।

$docker-compose down

यह बनाए गए किसी भी वॉल्यूम के अपवाद के साथ डॉकटर को एक स्वच्छ स्थिति में वापस कर देगा (हमने कोई भी नहीं बनाया है, इसलिए यह चिंता का विषय नहीं है।)

स्मृति सीमा और स्मृति आरक्षण

मेमोरी लिमिट और मेमोरी रिजर्वेशन दो अलग-अलग पहलू हैं जो आपके एप्लिकेशन और आपके द्वारा चलाए जा रहे डॉकर होस्ट के सुचारू संचालन को सुनिश्चित करते हैं।

मोटे तौर पर, मेमोरी लिमिट मेमोरी की मात्रा के लिए एक ऊपरी सीमा लगाती है जो संभावित रूप से एक डॉकर कंटेनर द्वारा उपयोग की जा सकती है। डिफ़ॉल्ट रूप से एक डॉकर कंटेनर, किसी भी अन्य सिस्टम प्रक्रिया की तरह, डॉकर होस्ट की संपूर्ण उपलब्ध मेमोरी का उपयोग कर सकता है। यह आउट-ऑफ-मेमोरी-अपवाद का कारण बन सकता है और आपका सिस्टम बहुत अच्छी तरह से क्रैश हो सकता है। यहां तक ​​​​कि अगर यह कभी नहीं आता है, तब भी यह मूल्यवान संसाधनों से अन्य प्रक्रियाओं (अन्य कंटेनरों सहित) को भूखा कर सकता है, फिर से प्रदर्शन को नुकसान पहुंचा सकता है। मेमोरी लिमिट सुनिश्चित करती है कि संसाधन के भूखे कंटेनर एक निश्चित सीमा से अधिक न हों। यह खराब लिखे गए एप्लिकेशन के ब्लास्ट रेडियस को कुछ कंटेनरों तक सीमित करता है, पूरे होस्ट को नहीं।

स्मृति आरक्षण, दूसरी ओर, कम कठोर है। जब सिस्टम कम मेमोरी पर चल रहा हो और उसमें से कुछ को पुनः प्राप्त करने का प्रयास करता हो। यह कंटेनर की मेमोरी खपत को आरक्षण सीमा पर या उससे कम लाने की कोशिश करता है। यदि स्मृति की प्रचुरता है, तथापि, अनुप्रयोग हार्ड सेट स्मृति सीमा तक विस्तारित हो सकता है।

संक्षेप में:

  1. मेमोरी लिमिट: एक कंटेनर को उपलब्ध कराई गई मेमोरी की मात्रा के लिए एक सख्त ऊपरी सीमा।
  2. मेमोरी रिजर्वेशन: इसे मेमोरी की न्यूनतम मात्रा के रूप में सेट किया जाना चाहिए जिसे किसी एप्लिकेशन को ठीक से चलाने की आवश्यकता होती है। इसलिए जब सिस्टम कुछ मेमोरी को पुनः प्राप्त करने का प्रयास कर रहा हो तो यह क्रैश या दुर्व्यवहार नहीं करता है।

यदि स्मृति आरक्षण स्मृति सीमा से अधिक है, तो स्मृति सीमा को प्राथमिकता दी जाती है।

स्मृति सीमा और आरक्षण निर्दिष्ट करना

संस्करण 2

आइए हम पहले लिखे गए docker-compose.yml पर वापस जाएं और इसमें एक मेमोरी लिमिट जोड़ें। पूर्वापेक्षाएँ अनुभाग में चर्चा किए गए कारणों के लिए संस्करण को 2.4 में बदलें।

संस्करण:'2.4'
सेवाएं:
मेरा-nginx:
छवि: nginx: नवीनतम
बंदरगाह:
-'80: 80'
mem_limit: 300m

अंतिम पंक्ति my-nginx सेवा की सीमा को 300MiB पर सेट करती है। आप KiB के लिए k का उपयोग कर सकते हैं, और GiB के लिए g और केवल बाइट्स के लिए b का उपयोग कर सकते हैं। हालाँकि, इससे पहले की संख्या एक पूर्णांक होनी चाहिए। आप 2.4m जैसे मानों का उपयोग नहीं कर सकते, आपको इसके बजाय 2400k का उपयोग करना होगा। अब यदि आप दौड़ते हैं:

$ डोकर स्टेट --all

कंटेनर आईडी नाम सीपीयू% एमईएम उपयोग/सीमा एमईएम% नेट I/O ब्लॉक I/O PIDS
44114d785d0a my-compose_my-nginx_10.00% 2.141MiB/300MiB0.71% 1.16kB/0B 0B/0B2

आप देखेंगे कि मेमोरी की सीमा 300 MiB पर सेट है। मेमोरी रिजर्वेशन सेट करना भी उतना ही आसान है, बस एक लाइन mem_reservation: xxx अंत में जोड़ें।

संस्करण:'2.4'
सेवाएं:
मेरा-nginx:
छवि: nginx: नवीनतम
बंदरगाह:
-'80: 80'
mem_limit: 300m
mem_reservation: 100m

संस्करण 3 (वैकल्पिक)

संस्करण तीन का उपयोग करने के लिए आपको डॉकर को झुंड मोड में चलाने की आवश्यकता है। विंडोज और मैक के लिए आप डॉकर सेटिंग्स मेनू का उपयोग करके इसे सक्षम कर सकते हैं। लिनक्स उपयोगकर्ताओं को docker swarm init चलाने की आवश्यकता होगी। उस पर अधिक जानकारी मिल सकती है यहां . हालांकि यह एक आवश्यक कदम नहीं है, और यदि आपने इसे सक्षम नहीं किया है, तो यह भी ठीक है। यह खंड लोगों के लिए है पहले से ही झुंड मोड में चल रहा है और नए संस्करण का उपयोग कर सकता है।

संस्करण:'3'
सेवाएं:
मेरा-nginx:
छवि: nginx: नवीनतम
बंदरगाह:
-'80: 80'
तैनाती:
साधन:
सीमाएं:
मेमोरी: 300m
आरक्षण:
मेमोरी: 100m

हम इन सभी को रिसोर्स ऑप्शन के तहत परिभाषित करते हैं। सीमाएं और आरक्षण स्वयं की प्राथमिक कुंजी बन जाते हैं और स्मृति यहां प्रबंधित किए जा रहे कई संसाधनों में से एक है। सीपीयू अभी तक एक और महत्वपूर्ण पैरामीटर है।

अग्रिम जानकारी

आप आधिकारिक दस्तावेज से डॉकटर-कंपोज़ के बारे में अधिक जान सकते हैं यहाँ जुड़ा हुआ है . एक बार जब आप एक कंपोज़ फ़ाइल लिखने का सार प्राप्त कर लेते हैं, तो दस्तावेज़ीकरण आपको विभिन्न मापदंडों की विशिष्टताओं के साथ मदद कर सकता है।

आपको सब कुछ जानने की जरूरत नहीं है, बस अपने आवेदन के लिए जो चाहिए उसे खोजें और संदर्भ आपको इसे लागू करने में मार्गदर्शन करेगा।