कुबेरनेट्स - निगरानी

बड़े समूहों के प्रबंधन के लिए निगरानी एक प्रमुख घटक है। इसके लिए, हमारे पास कई उपकरण हैं।

प्रोमेथियस के साथ निगरानी

यह एक निगरानी और चेतावनी प्रणाली है। यह साउंडक्लाउड में बनाया गया था और 2012 में खुला था। यह बहुआयामी डेटा को बहुत अच्छी तरह से संभालता है।

प्रोमेथियस के पास निगरानी में भाग लेने के लिए कई घटक हैं -

  • Prometheus - यह मुख्य घटक है जो डेटा को स्क्रैप और स्टोर करता है।

  • Prometheus node explore - मेजबान स्तर के मैच्योर हो जाते हैं और उन्हें प्रोमेथियस को उजागर करते हैं।

  • Ranch-eye - ए है haproxy और उजागर करता है cAdvisor प्रोमेथियस को आँकड़े।

  • Grafana - डेटा का विज़ुअलाइज़ेशन।

  • InfuxDB - टाइम सीरीज़ डेटाबेस विशेष रूप से रैंचर के डेटा को स्टोर करने के लिए उपयोग किया जाता है।

  • Prom-ranch-exporter - यह एक साधारण नोड.जेएस एप्लिकेशन है, जो सेवा के स्टैक की स्थिति के लिए रैंचर सर्वर को क्वेरी करने में मदद करता है।

सेमाटेक्स्ट डॉकर एजेंट

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

एजेंटों को नोड्स में तैनात करना

Kubernetes DeamonSets प्रदान करता है जो सुनिश्चित करता है कि फली को क्लस्टर में जोड़ा जाता है।

SemaText Docker Agent को कॉन्फ़िगर करना

यह पर्यावरण चर के माध्यम से कॉन्फ़िगर किया गया है।

  • यदि आपके पास पहले से कोई खाता नहीं है, तो apps.sematext.com पर एक निःशुल्क खाता प्राप्त करें ।

  • SPM ऐप टोकन प्राप्त करने के लिए "Docker" प्रकार का एक SPM ऐप बनाएं। एसपीएम ऐप आपके कुबेरनेट्स प्रदर्शन मेट्रिक्स और ईवेंट का आयोजन करेगा।

  • Logsene App टोकन प्राप्त करने के लिए एक Logsene App बनाएं। Logsene App आपके Kubernetes लॉग को रखेगा।

  • नीचे दिखाए गए अनुसार DaemonSet परिभाषा में LOGSENE_TOKEN और SPM_TOKEN के मान संपादित करें।

    • नवीनतम sematext-agent-daemonset.yml (रॉ प्लेन-टेक्स्ट) टेम्प्लेट (नीचे दिखाया गया है) को भी पकड़ो।

    • इसे डिस्क पर कहीं स्टोर करें।

    • SPM_TOKEN और LOGSENE_TOKEN प्लेसहोल्डर्स को अपने SPM और Logsene App टोकन से बदलें।

DaemonSet ऑब्जेक्ट बनाएँ

apiVersion: extensions/v1beta1
kind: DaemonSet
metadata:
   name: sematext-agent
spec:
   template:
      metadata:
         labels:
            app: sematext-agent
      spec:
         selector: {}
         dnsPolicy: "ClusterFirst"
         restartPolicy: "Always"
         containers:
         - name: sematext-agent
            image: sematext/sematext-agent-docker:latest
            imagePullPolicy: "Always"
            env:
            - name: SPM_TOKEN
               value: "REPLACE THIS WITH YOUR SPM TOKEN"
            - name: LOGSENE_TOKEN
               value: "REPLACE THIS WITH YOUR LOGSENE TOKEN"
            - name: KUBERNETES
               value: "1"
            volumeMounts:
               - mountPath: /var/run/docker.sock
                  name: docker-sock
               - mountPath: /etc/localtime
                  name: localtime
            volumes:
               - name: docker-sock
                  hostPath:
                     path: /var/run/docker.sock
               - name: localtime
                  hostPath:
                     path: /etc/localtime

कुबेटेल के साथ सेमाटेक्स्ट एजेंट डोकर चलाना

$ kubectl create -f sematext-agent-daemonset.yml
daemonset "sematext-agent-daemonset" created

कुबेरनेट्स लॉग

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

  • कुबेरनेट्स नेमस्पेस
  • कुबेरनेट्स पॉड नाम
  • कुबेरनेट्स कंटेनर नाम
  • डॉकर छवि नाम
  • कुबेरनेट्स यूआईडी

एल्क स्टैक और लॉगस्पाउट का उपयोग करना

ईएलके स्टैक में एलिस्टिक्स खोज, लॉगस्टैश और किबाना शामिल हैं। लॉगिंग प्लेटफ़ॉर्म पर लॉग को इकट्ठा करने और आगे बढ़ाने के लिए, हम लॉगस्पाउट का उपयोग करेंगे (हालांकि फ़्लुएंटीडी जैसे अन्य विकल्प भी हैं)।

निम्नलिखित कोड दिखाता है कि कुबेरनेट्स पर ELK क्लस्टर कैसे सेट करें और ElasticSearch के लिए सेवा बनाएं -

apiVersion: v1
kind: Service
metadata:
   name: elasticsearch
   namespace: elk
   labels:
      component: elasticsearch
spec:
   type: LoadBalancer
   selector:
      component: elasticsearch
   ports:
   - name: http
      port: 9200
      protocol: TCP
   - name: transport
      port: 9300
      protocol: TCP

प्रतिकृति नियंत्रक बनाना

apiVersion: v1
kind: ReplicationController
metadata:
   name: es
   namespace: elk
   labels:
      component: elasticsearch
spec:
   replicas: 1
   template:
      metadata:
         labels:
            component: elasticsearch
spec:
serviceAccount: elasticsearch
containers:
   - name: es
      securityContext:
      capabilities:
      add:
      - IPC_LOCK
   image: quay.io/pires/docker-elasticsearch-kubernetes:1.7.1-4
   env:
   - name: KUBERNETES_CA_CERTIFICATE_FILE
   value: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
   - name: NAMESPACE
   valueFrom:
      fieldRef:
         fieldPath: metadata.namespace
   - name: "CLUSTER_NAME"
      value: "myesdb"
   - name: "DISCOVERY_SERVICE"
      value: "elasticsearch"
   - name: NODE_MASTER
      value: "true"
   - name: NODE_DATA
      value: "true"
   - name: HTTP_ENABLE
      value: "true"
ports:
- containerPort: 9200
   name: http
   protocol: TCP
- containerPort: 9300
volumeMounts:
- mountPath: /data
   name: storage
volumes:
   - name: storage
      emptyDir: {}

किबना यूआरएल

किबाना के लिए, हम एक पर्यावरण चर के रूप में एलेस्टिक्स खोज URL प्रदान करते हैं।

- name: KIBANA_ES_URL
value: "http://elasticsearch.elk.svc.cluster.local:9200"
- name: KUBERNETES_TRUST_CERT
value: "true"

किबाना यूआई कंटेनर पोर्ट 5601 और इसी होस्ट / नोड पोर्ट संयोजन पर उपलब्ध होगा। जब आप शुरू करते हैं, तो Kibana में कोई डेटा नहीं होगा (जो कि अपेक्षित है कि आपने किसी डेटा को धक्का नहीं दिया है)।