paint-brush
ग्राफाना लोकी को कैसे तैनात करें और डॉकर कंटेनरों का उपयोग करके या स्रोत से सीधे डेटा को मिनियो में कैसे सहेजें द्वारा@minio
11,702 रीडिंग
11,702 रीडिंग

ग्राफाना लोकी को कैसे तैनात करें और डॉकर कंटेनरों का उपयोग करके या स्रोत से सीधे डेटा को मिनियो में कैसे सहेजें

द्वारा MinIO
MinIO HackerNoon profile picture

MinIO

@minio

MinIO is a high-performance, cloud-native object store that runs...

11 मिनट read2023/08/01
Read on Terminal Reader
Read this story in a terminal
Print this story

बहुत लंबा; पढ़ने के लिए

हालांकि आम बात है, लॉग सिस्टम संचालन के बारे में महत्वपूर्ण जानकारी रखते हैं और डिबगिंग और समस्या निवारण जानकारी का एक मूल्यवान स्रोत हैं।
featured image - ग्राफाना लोकी को कैसे तैनात करें और डॉकर कंटेनरों का उपयोग करके या स्रोत से सीधे डेटा को मिनियो में कैसे सहेजें
MinIO HackerNoon profile picture
MinIO

MinIO

@minio

MinIO is a high-performance, cloud-native object store that runs anywhere (public cloud, private cloud, colo, onprem).

0-item
1-item

STORY’S CREDIBILITY

Vested Interest

Vested Interest

This writer has a vested interest be it monetary, business, or otherwise, with 1 or more of the products or companies mentioned within.

Code License

Code License

The code in this story is for educational purposes. The readers are solely responsible for whatever they build with it.

ग्राफाना लोकी एक लॉग एकत्रीकरण प्रणाली है जो अनुप्रयोगों और बुनियादी ढांचे से लॉग को संग्रहीत और क्वेरी करती है। हालांकि आम बात है, लॉग सिस्टम संचालन के बारे में महत्वपूर्ण जानकारी रखते हैं और डिबगिंग और समस्या निवारण जानकारी का एक मूल्यवान स्रोत हैं। लॉग का उपयोग अक्सर दुर्भावनापूर्ण गतिविधि को पहचानने और ट्रैक करने के लिए, या बस व्यावसायिक खुफिया जानकारी प्रदान करने के लिए उपयोगकर्ता गतिविधि को ट्रैक करने के लिए किया जाता है।


पिछले ब्लॉग पोस्ट, ग्राफाना लोकी और मिनिओ के साथ लॉगिंग में, हमने लोकी के घटकों और उनकी समग्र वास्तुकला का एक सिंहावलोकन प्रदान किया था। लॉग के लिए लोकी को मेट्रिक्स के लिए प्रोमेथियस के समान समझें। लोकी हल्का और लागत प्रभावी है क्योंकि यह केवल मेटाडेटा को अनुक्रमित और क्वेरी करता है। प्रोमटेल एजेंट लोकी को भेजने से पहले लॉग एकत्र करते हैं, लेबल करते हैं और उन्हें रूपांतरित करते हैं। फिर लोकी मेटाडेटा को अनुक्रमित करता है और प्रविष्टियों को स्ट्रीम में समूहित करता है जिन्हें लेबल के साथ अनुक्रमित किया जाता है। फिर ग्राफाना का उपयोग लोकी से लॉग जानकारी को विज़ुअलाइज़ करने और क्वेरी करने के लिए किया जाता है। संस्करण 2.0 के अनुसार, लोकी डेटा को मिनिओ जैसे एकल ऑब्जेक्ट स्टोरेज बैकएंड में संग्रहीत करता है। जबकि पिछले ब्लॉग पोस्ट में मिनिओ को लोकी डेटा को सहेजने के फायदे बताए गए थे, यह ब्लॉग पोस्ट एक ट्यूटोरियल है जो आपको सिखाता है कि कैसे।


सबसे पहले, हम आपको सिखाएंगे कि डॉकर कंटेनरों का उपयोग करके लोकी और मिनिओ को कैसे तैनात किया जाए, इसके बाद स्रोत से इंस्टॉल करने के निर्देश दिए जाएंगे।

डॉकर कंटेनरों का उपयोग करके लोकी और मास्टर मिनिओ सीखें

हमने डॉकर कंटेनर, कुछ स्क्रिप्टिंग और एक गिट रिपॉजिटरी का उपयोग करके एक डेमो बनाया। हमने ग्राफाना लोकी रिपॉजिटरी के साथ शुरुआत की, और मिनिओ के लिए कॉन्फ़िगरेशन yaml और कंटेनर और लोकी डेटा के लिए मिनिओ बाल्टी बनाने और उजागर करने के लिए एक स्क्रिप्ट जोड़ी। निम्नलिखित चरणों के परिणामस्वरूप ये पाँच छवियाँ डॉकर कंटेनरों में स्थानीय रूप से चलेंगी:


  • लोकी
  • प्रोमटेल
  • ग्राफाना
  • मिनिओ
  • बाल्टियाँ बनाएँ


पहले तीन स्पष्ट रूप से लोकी, प्रोमटेल और ग्राफाना के लिए आवश्यक हैं। वे लोकी रिपॉजिटरी के तहत ग्राफाना से पहले से ही उपलब्ध थे (एक लघु वीडियो व्याख्याता है)। मिनिओ लोकी के लिए ऑब्जेक्ट स्टोरेज है, और अंतिम कंटेनर एक स्क्रिप्ट चलाएगा जो लोकी लक्ष्य के रूप में बकेट बनाता है।


लोकी को loki.yaml का उपयोग करके लॉग डेटा को MiniIO में सहेजने के लिए कॉन्फ़िगर किया गया है। विशेष महत्व का अनुभाग है:


 storage_config: boltdb_shipper: active_index_directory: /loki/index cache_location: /loki/index_cache resync_interval: 5s shared_store: s3 aws: s3: http://minioadmin:minioadmin@minio.:9000/loki s3forcepathstyle: true


MiniIO के लिए S3 पते में बिंदु नोट करें। इसका उपयोग इसलिए किया जाता है क्योंकि AWS क्षेत्र निर्दिष्ट करने की कोई आवश्यकता नहीं है।


हम docker-compose.yaml फ़ाइल का उपयोग करके एक Docker वातावरण बनाते हैं। हम कंटेनर, वॉल्यूम, पोर्ट, नेटवर्क कॉन्फ़िगर करेंगे और स्टार्टअप कमांड प्रदान करेंगे।


loki छवि को वॉल्यूम के माध्यम से लोकी कॉन्फ़िगरेशन तक पहुंच के साथ एक कंटेनर के रूप में चलाने के लिए:


 services: loki: image: grafana/loki:latest volumes: - <your-local-path>/loki/production:/home/loki/production ports: - "3100:3100" command: -config.file=/home/loki/production/loki.yaml networks: - loki


पहला कॉन्फ़िगरेशन जो आपको करने की आवश्यकता होगी वह यह सुनिश्चित करना है कि आपके production का स्थानीय फ़ोल्डर कंटेनर के साथ साझा किया जा रहा है। होस्ट सिस्टम पर स्थानीय फ़ोल्डर को संदर्भित करने के लिए कृपया अपने docker-compose.yaml के volumes अनुभाग को संपादित करें जहां आपने production फ़ोल्डर डाउनलोड किया है। हम loki.yaml पढ़ने के लिए होस्ट पथ को कंटेनर पथ पर मैप कर रहे हैं।


docker-compose.yaml में, हम एक नेटवर्क को भी परिभाषित करते हैं और MiniIO सर्वर चलाने वाले कंटेनर के पोर्ट को उजागर करते हैं। इस मामले में, ब्राउज़र के साथ मिनिओ सर्वर तक पहुंचने के लिए पोर्ट 9000 और 9001 को आपकी स्थानीय मशीन पर प्रदर्शित किया जाएगा।


 Console UI: minio: image: minio/minio:latest ports: - "9000:9000" - "9001:9001" networks: - loki command: server ~ --address ':9000' --console-address ':9001'


हम loki नेटवर्क साझा करने वाले सभी कंटेनरों के साथ नेटवर्क को कॉन्फ़िगर करते हैं। प्रत्येक कंटेनर दूसरे को पिंग कर सकता है और उनके एपीआई का उपयोग कर सकता है। अपने कंटेनरों के लिए निश्चित आईपी पते का उपयोग न करें। इसे आसान बनाने के लिए, हमने उपयुक्त कंटेनर को हल करने के लिए अपने वातावरण में loki और minio कॉन्फ़िगर किया है। उदाहरण के लिए:

 http://minio:9000 for MinIO http://loki:3100 for Loki http://loki:3000 for Grafana


docker-compose.yaml द्वारा की गई अगली कार्रवाई मिनियो सर्वर को कॉन्फ़िगर करने के लिए एक कंटेनर में मिनियो क्लाइंट (एमसी) को चलाने, लोकी डेटा के लिए गंतव्य बकेट बनाने और आवश्यकतानुसार एक्सेस नीति को public के लिए सेट करना है।


 createbuckets: image: minio/mc networks: - loki depends_on: - minio entrypoint: > /bin/sh -c " /usr/bin/mc config host add myminio http://minio:9000 minioadmin minioadmin; /usr/bin/mc rm -r --force myminio/loki; /usr/bin/mc mb myminio/loki; /usr/bin/mc policy set public myminio/loki; exit 0; "


प्रोमटेल, एक छोटा गो प्रोग्राम है, जिसका उपयोग वितरित लॉग फ़ाइलों को ट्रैक करने या एकत्र करने और उन्हें लोकी तक पहुंचाने के लिए किया जाता है। इस डेमो के लिए Promtail को इसके कंटेनर में एक कॉन्फ़िगरेशन फ़ाइल के साथ तैनात किया गया है जो /var/log निर्देशिका को स्क्रैप करता है। इस डेमो को चलाने के लिए और उस स्थान पर लॉग फ़ाइलों को संसाधित करने के लिए किसी बदलाव की आवश्यकता नहीं है - /var/log।


इस ट्यूटोरियल के अंत में हम देखेंगे कि प्रोमटेल को लॉग फ़ाइलों के लिए सिस्टम पर अन्य स्थानों को कैसे स्क्रैप करना है।

कदम

अब जब आप समझ गए हैं कि लोकी, प्रोमटेल और अपने डॉकर वातावरण को कैसे कॉन्फ़िगर किया जाए, तो कृपया डेमो वातावरण को कॉन्फ़िगर करने और चलाने के लिए इन चरणों का पालन करें। निम्न चरणों में docker-compose.yaml , loki.yaml और डिफ़ॉल्ट Promtail कॉन्फ़िगरेशन का उपयोग यह प्रदर्शित करने के लिए किया जाता है कि लोकी मिनिओ के साथ कैसे काम करता है। हमारी फ़ाइलें डाउनलोड करने के बाद, उन्हें अपने परिवेश के लिए संपादित करें।


इस रिपॉजिटरी को क्लोन करें https://github.com/cniackz/loki :

git clone https://github.com/cniackz/loki.git minio-loki-tutorial


निर्देशिका को अपने स्थानीय production फ़ोल्डर में बदलें:


https://github.com/cniackz/loki/tree/main/production


 cd <your-local-path>/minio-loki-tutorial/production Edit docker-compose.yaml to reference your local home directory If necessary, edit promtail.yaml


अपना स्थानीय डॉकर वातावरण बनाएं:

docker-compose build --no-cache


स्थानीय डॉकर कंटेनर लॉन्च करें:

docker-compose up -d


यह पुष्टि करने के लिए कि लोकी डेटा मिनिओ में सहेजा जा रहा है, http://localhost:9001 या http://minio:9001 पर मिनियो कंसोल में लॉग इन करें। यह ट्यूटोरियल निम्नलिखित क्रेडेंशियल्स का उपयोग करता है:


 user: minioadmin password: minioadmin 


image


लॉग इन करने के बाद Buckets पर क्लिक करें। आपको देखना चाहिए कि लोकी बकेट बन गया है।


image


दाईं ओर, नव निर्मित बकेट की सामग्री देखने के लिए ब्राउज़ पर क्लिक करें। आपको loki अंतर्गत fake निर्देशिका देखनी चाहिए। यहीं पर लोकी डेटा सेव करेगा।


image


fake निर्देशिका खोलने के लिए उसके नाम पर क्लिक करें। लोकी एक कॉन्फ़िगर अंतराल के लिए मेमोरी में लॉग रखता है और फिर उन्हें ऑब्जेक्ट स्टोरेज में लिखता है। डिफ़ॉल्ट 5 मिनट का अंतराल है, इसलिए कृपया अपने बकेट में डेटा प्रदर्शित होने के लिए 5 मिनट प्रतीक्षा करें।


image


इस बिंदु पर, प्रोमटेल लोकी को लॉग भेज रहा है और लोकी मिनिओ को डेटा सहेज रहा है। अब, लोकी लॉग देखने के लिए ग्राफाना को सेट करें। ग्राफाना 6.0 और उच्चतर में लोकी के लिए अंतर्निहित समर्थन शामिल है। ग्राफाना 6.3 और उच्चतर में लॉगक्यूएल कार्यक्षमता के लिए समर्थन शामिल है।


http://loki:3000 पर ग्राफाना में लॉग इन करें (डिफ़ॉल्ट क्रेडेंशियल एडमिन: एडमिन हैं)।


ग्राफाना में, कॉन्फ़िगरेशन और फिर डेटा स्रोतों पर जाने के लिए बाएं साइडबार पर कॉग आइकन पर क्लिक करें। बड़े डेटा स्रोत जोड़ें बटन पर क्लिक करें और फिर लोकी का चयन करें।


image


डॉकर पोर्ट मैपिंग का उपयोग करके स्थानीय रूप से चलने वाले हमारे लोकी सर्वर के लिए http URL फ़ील्ड को संपादित करें: http://loki:3100


image


फिर सेव एंड टेस्ट पर क्लिक करें।


लॉग तुरंत देखने के लिए, एक्सप्लोर पर क्लिक करें। आप बाएं साइडबार में एक्सप्लोर पर क्लिक करके भी लॉग देख सकते हैं। हालाँकि आप एक्सप्लोर करते हैं, फिर शीर्ष-बाएँ ड्रॉपडाउन में लोकी डेटास्रोत का चयन करें, और फिर लॉग लेबल बटन का उपयोग करके एक लॉग स्ट्रीम चुनें।


image


आप एक LogQL क्वेरी टाइप कर सकते हैं और रन क्वेरी पर क्लिक कर सकते हैं। हालाँकि, यदि आप अभी तक LogQL नहीं जानते हैं, तो आप लॉग और क्वेरी पैरामीटर का चयन करने के लिए GUI का उपयोग कर सकते हैं।


लोकी में मौजूद लॉग को तुरंत देखने के लिए, लॉग ब्राउज़र पर क्लिक करें, फिर 1. Select labels to search in और job चुनें, फिर 2. Find values for the selected labels अपने काम के नाम पर क्लिक करें ( promtail-local-config.yaml से) promtail-local-config.yaml ). इस मामले में मैंने varlogs पर क्लिक किया है। फिर शो लॉग्स बटन पर क्लिक करें।


आप समय सीमा का चयन कर सकते हैं और ब्राउज़र विंडो के शीर्ष दाईं ओर क्वेरी का ताज़ा अंतराल सेट कर सकते हैं।


image


लॉग के अधिक विवरण देखने के लिए, नीचे स्क्रॉल करें और लॉग प्रविष्टियों में से एक पर क्लिक करें, यह लॉग प्रविष्टि से संबंधित अतिरिक्त जानकारी प्रदान करेगा।


image


वास्तव में एक शक्तिशाली सुविधा आइकन पर क्लिक करके लॉग विवरण से सीधे labels और fields के बारे में आंकड़ों को फ़िल्टर करने या देखने की क्षमता है। यह समस्या निवारण को सरल बनाता है क्योंकि इससे आवर्ती त्रुटियों को देखना और खोज शब्दों के बीच पिवोट करना आसान हो जाता है।

डेमो का विस्तार

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


Promtail कंटेनर से पहुंच योग्य 2 नए वॉल्यूम बनाने के लिए docker-compose.yaml फ़ाइल को संपादित करें। पहला होस्ट सिस्टम पर उस निर्देशिका तक पहुंच प्रदान करता है जहां नई कॉन्फ़िगरेशन फ़ाइल बनाई जाएगी। दूसरा एक निर्देशिका तक पहुंच प्रदान करता है जिसमें रुचि की लॉग फ़ाइलें होंगी। इसके अतिरिक्त, Promtail को नई कॉन्फ़िग फ़ाइल का संदर्भ देते हुए लॉन्च किया जाएगा, जिसे हमने promtail-local-config.yaml कहा है:


 version: "3" networks: loki: services: loki: image: grafana/loki:latest volumes: - <your-local-path>/loki/minio-loki-tutorial/production:/home/loki/production ports: - "3100:3100" command: -config.file=/home/loki/production/loki.yaml networks: - loki promtail: image: grafana/promtail:2.4.2 volumes: - /var/log:/var/log -- <your-local-path>/loki/minio-loki-tutorial/production:/home/loki/production -- <your-local-path>/access_logs:/home/loki/access_logs command: -config.file=/home/loki/production/promtail-local-config.yaml networks: - loki grafana: image: grafana/grafana:latest ports: - "3000:3000" networks: - loki minio: image: minio/minio:latest ports: - "9000:9000" - "9001:9001" networks: - loki command: server ~ --address ':9000' --console-address ':9001' createbuckets: image: minio/mc networks: - loki depends_on: - minio entrypoint: > /bin/sh -c " /usr/bin/mc config host add myminio http://minio:9000 minioadmin minioadmin; /usr/bin/mc rm -r --force myminio/loki; /usr/bin/mc mb myminio/loki; /usr/bin/mc policy set public myminio/loki; exit 0; "


ग्राफाना में लॉग डेटा के साथ आप और भी बहुत कुछ कर सकते हैं। शुरुआत के लिए, आप लोकी से अधिक लॉग जोड़ने के लिए अधिक स्थानों पर प्रोमटेल स्थापित कर सकते हैं। निष्पादन योग्य और promtail-local-config.yaml अन्य मशीनों/इंस्टेंस/कंटेनरों में कॉपी करें, Promtail कॉन्फ़िगरेशन में वर्णित कॉन्फ़िगरेशन को संपादित करें और इसे चलाएं।


अब हमें लोकी को स्थानीय सिस्टम लॉग भेजने के लिए Promtail config फ़ाइल, promtail-local-config.yaml बनाने की आवश्यकता है। ग्राफाना से एक नमूना कॉन्फ़िग फ़ाइल डाउनलोड करें और संपादित करें। जिस अनुभाग पर ध्यान केंद्रित करना है वह scrape_configs है क्योंकि यहीं पर प्रोमटेल को बताया जाता है कि कौन से लॉग को खींचना है, उन्हें कैसे प्रारूपित करना है और उन्हें कहां भेजना है। कृपया प्रोमटेल को कॉन्फ़िगर करने के बारे में अधिक जानकारी के लिए लोकी में लॉग प्राप्त करें देखें।


scrape_configs अनुभाग में निम्नलिखित शामिल हैं:


  • job_name - यह एकत्रित लॉग को अन्य लॉग समूहों से अलग करता है।
  • लक्ष्य - static_configs के लिए वैकल्पिक। हालाँकि, इसे अक्सर परिभाषित किया जाता है क्योंकि Promtail के पुराने संस्करणों में यह वैकल्पिक नहीं था। यह सीधे प्रोमेथियस सेवा खोज कोड का उपयोग करने से प्राप्त एक कलाकृति थी, जिसके लिए इस प्रविष्टि की आवश्यकता थी।
  • लेबल - इस परिभाषा द्वारा स्क्रैप की गई प्रत्येक लॉग लाइन पर लागू होने वाला स्टेटिक लेबल। अच्छे उदाहरणों में पर्यावरण का नाम, कार्य का नाम, या ऐप का नाम शामिल है।
  • पथ - वह पथ जहां लोकी द्वारा उपभोग किए जाने वाले लॉग संग्रहीत हैं।


 server: http_listen_port: 9080 grpc_listen_port: 0 positions: filename: /tmp/positions.yaml clients: - url: http://loki:3100/loki/api/v1/push scrape_configs: - job_name: apache static_configs: - targets: - localhost labels: job: access_logs __path__: /home/loki/access_logs/*log


प्रोमटेल में स्क्रैपिंग के लिए विभिन्न कॉन्फ़िगरेशन विकल्पों को समझना महत्वपूर्ण है, और ग्राफाना बहुत सारे विवरण प्रदान करता है।


एप्लिकेशन की पूर्ण क्षमताओं को देखने के लिए पूर्ण प्रोमटेल कॉन्फ़िगरेशन संदर्भ से परामर्श करना सहायक हो सकता है।


अंत में, कुछ अपाचे वेब सर्वर एक्सेस लॉग को होस्ट सिस्टम पर docker-compose.yaml फ़ाइल में निर्दिष्ट निर्देशिका में रखें। ये वे लॉग हैं जिन्हें प्रोमटेल ग्रहण करेगा और प्रसंस्करण के लिए लोकी को भेजेगा:


-- <your-local-path>/access_logs:/home/loki/access_logs


एक बार संपादन हो जाने और नमूना अपाचे एक्सेस लॉग स्थापित हो जाने के बाद, कंटेनरों को नीचे लाएँ और डॉकर कंपोज़ के साथ बैकअप लें:


 docker-compose down docker-compose up -d


प्रोमटेल बाद में नई अपाचे एक्सेस लॉग फ़ाइलों को लोड करेगा और उन्हें लोकी के लिए उपलब्ध कराएगा।


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

निष्कर्ष

Grafana, Prometheus और AlertManager के अवलोकनीयता स्टैक को लोकी के साथ एक शक्तिशाली वृद्धि प्राप्त हुई (BTW, हमारे पास MiniIO पर Grafana, Prometheus और AlertManager के लिए एक ट्यूटोरियल भी है)। वितरित सिस्टम, विशेष रूप से जब कुबेरनेट्स द्वारा कंटेनरीकृत और ऑर्केस्ट्रेटेड होते हैं, तो उनके अनुप्रयोगों और माइक्रोसर्विसेज के लिए कई लॉग होते हैं। मिनिओ के साथ संयुक्त लोकी लॉग एकत्र करने, संग्रहीत करने और क्वेरी करने का एक लागत प्रभावी तरीका है।


यदि आपके कोई प्रश्न हैं, तो कृपया हमें hello@min.io पर एक ईमेल भेजें, या मिनियो स्लैक चैनल से जुड़ें और पूछें।


यहाँ भी प्रकाशित किया गया है.


L O A D I N G
. . . comments & more!

About Author

MinIO HackerNoon profile picture
MinIO@minio
MinIO is a high-performance, cloud-native object store that runs anywhere (public cloud, private cloud, colo, onprem).

लेबल

इस लेख में चित्रित किया गया था...

Read on Terminal Reader
Read this story in a terminal
 Terminal
Read this story w/o Javascript
Read this story w/o Javascript
 Lite
Also published here
X REMOVE AD