ในบทความนี้คุณจะได้เรียนรู้วิธีเผยแพร่ข้อมูลเหตุการณ์คลัสเตอร์ Kubernetes ไปยัง Amazon โดยใช้ Fluentd logging agent จากนั้นข้อมูลจะถูกดูโดยใช้ เครื่องมือสร้างภาพแบบโอเพนซอร์สสำหรับ Elasticsearch Amazon ES ประกอบด้วยการรวม Kibana ในตัว
เราจะแนะนำคุณตลอดขั้นตอนต่อไปนี้:
- การสร้างคลัสเตอร์ Kubernetes
- การสร้างคลัสเตอร์ Amazon ES
- ปรับใช้ Fluentd Logging Agent บนคลัสเตอร์ Kubernetes
- เห็นภาพวันที่ kubernetes ใน Kibana
ขั้นตอนที่ 1: การสร้างคลัสเตอร์ Kubernetes
Kubernetes เป็นแพลตฟอร์มโอเพ่นซอร์สที่ Google สร้างขึ้นเพื่อจัดการแอปพลิเคชันที่มีคอนเทนเนอร์ ช่วยให้คุณจัดการปรับขนาดและปรับใช้แอปที่มีคอนเทนเนอร์ของคุณในสภาพแวดล้อมคลัสเตอร์ เราสามารถจัดเตรียมคอนเทนเนอร์ของเราในโฮสต์ต่างๆด้วย ผู้ว่าการ ปรับขนาดแอปที่บรรจุด้วยทรัพยากรทั้งหมดได้ทันทีและมีสภาพแวดล้อมการจัดการคอนเทนเนอร์แบบรวมศูนย์
เราจะเริ่มต้นด้วยการสร้างคลัสเตอร์ Kubernetes และฉันจะสาธิตวิธีการติดตั้งและกำหนดค่า Kubernetes บน CentOS 7 ทีละขั้นตอน
หนึ่ง. กำหนดค่าโฮสต์
วิธีใช้พาวเวอร์ใน java
- vi / etc / โฮสต์
- ทำการเปลี่ยนแปลงตามรายละเอียดโฮสต์ของคุณในไฟล์โฮสต์
2. ปิดการใช้งาน SELinux โดยดำเนินการคำสั่งด้านล่าง
- setenforce 0
- sed -i –follow-symlinks 's / SELINUX = บังคับใช้ / SELINUX = disabled / g' / etc / sysconfig / selinux
3. เปิดใช้งาน br_netfilter Kernel Module
โมดูล br_netfilter จำเป็นสำหรับการติดตั้ง kubernetes รันคำสั่งด้านล่างเพื่อเปิดใช้งานโมดูลเคอร์เนล br_netfilter- modprobe br_netfilter
- echo ‘1’> / proc / sys / net / bridge / bridge-nf-call-iptables
สี่. ปิดการใช้งาน SWAP โดยเรียกใช้คำสั่งด้านล่าง
- swapoff -a
- จากนั้นแก้ไข / etc / fstab และแสดงความคิดเห็นที่ swap line
5. ติดตั้ง Docker CE เวอร์ชันล่าสุดติดตั้งการอ้างอิงแพ็คเกจสำหรับนักเทียบท่าโดยเรียกใช้คำสั่งด้านล่าง
- yum install -y yum-utils device-mapper-persistent-data lvm2
- yum-config-manager –add-repo https://download.docker.com/linux/centos/docker-ce.repo
- ติดตั้ง yum -y docker-ce
6. ติดตั้ง Kubernetes
ใช้คำสั่งต่อไปนี้เพื่อเพิ่มที่เก็บ kubernetes เข้ากับระบบ centos 7- ยำติดตั้ง -y kubelet bebeadm kubectl
[kubernetes] name = Kubernetes baseurl = https: //packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64 เปิดใช้งาน = 1 gpgcheck = 1 repo_gpgcheck = 1 gpgkey = https: //packages.cloud.google. com / yum / doc / yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg EOFติดตั้งไฟล์ แพ็กเกจ kubeadm, kubelet และ kubectl โดยใช้คำสั่ง yum ด้านล่าง
- systemctl start docker && systemctl เปิดใช้งานนักเทียบท่า
หลังจากการติดตั้งเสร็จสมบูรณ์ให้รีสตาร์ทเซิร์ฟเวอร์เหล่านั้นทั้งหมดหลังจากรีสตาร์ทให้เริ่มการทำงานของ services docker และ kubelet
- systemctl start docker && systemctl เปิดใช้งานนักเทียบท่า
- systemctl start kubelet && systemctl เปิดใช้งาน kubelet
- systemctl start kubelet && systemctl เปิดใช้งาน kubelet
https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
เครือข่ายผ้าสักหลาดถูกนำไปใช้กับคลัสเตอร์ Kubernetes แล้ว รอสักครู่แล้วตรวจสอบโหนด kubernetes และพ็อดโดยใช้คำสั่งด้านล่าง- kubectl รับโหนด
- kubectl รับพ็อด - เนมสเปซทั้งหมด
9. การเพิ่มโหนดในคลัสเตอร์เชื่อมต่อกับเซิร์ฟเวอร์ node01 และรันคำสั่ง kubeadm join
- kubeadm เข้าร่วม 172.31.7.47:6443 –token at03m9.iinkh5ps9q12sh2i –discovery-token-ca-cert-hash sha256: 3f6c1824796ef1ff3d9427c883bde915d5bc13331d74891d831f29a8c4c4a
เชื่อมต่อกับเซิร์ฟเวอร์ node02 และรันคำสั่ง kubeadm join
- kubeadm เข้าร่วม 172.31.7.47:6443 –token at03m9.iinkh5ps9q12sh2i –discovery-token-ca-cert-hash sha256: 3f6c1824796ef1ff3d9427c883bde915d5bc13331d74891d831f29a8c4c4a
รอสักครู่และตรวจสอบเซิร์ฟเวอร์คลัสเตอร์หลัก 'k8s-master' ตรวจสอบโหนดและพ็อดโดยใช้คำสั่งต่อไปนี้
- kubectl รับโหนด
ตอนนี้คุณจะได้รับเพิ่ม worker1 และ worker2 ในคลัสเตอร์ด้วยสถานะ 'พร้อม'
- kubectl รับพ็อด - เนมสเปซทั้งหมด
การเริ่มต้นและการกำหนดค่าหลักคลัสเตอร์ Kubernetes เสร็จสมบูรณ์แล้ว
ขั้นตอนที่ 2: การสร้างคลัสเตอร์ Amazon ES
Elasticsearch เป็นเครื่องมือค้นหาและวิเคราะห์โอเพ่นซอร์สซึ่งใช้สำหรับการวิเคราะห์บันทึกและการตรวจสอบแอปพลิเคชันแบบเรียลไทม์ Amazon Elasticsearch Service (Amazon ES) เป็นบริการ AWS ที่ช่วยให้สามารถปรับใช้การใช้งานและขนาดของ Elasticsearch ใน AWS Cloud ได้ คุณสามารถใช้ Amazon ES เพื่อวิเคราะห์เหตุการณ์การส่งอีเมลจาก Amazon SES ของคุณ
เราจะสร้างคลัสเตอร์ Amazon ES จากนั้นปรับใช้ Fluentd logging agent ไปยังคลัสเตอร์ Kubernetes ซึ่งจะรวบรวมบันทึกและส่งไปยังคลัสเตอร์ Amazon ES
ส่วนนี้แสดงวิธีใช้คอนโซล Amazon ES เพื่อสร้างคลัสเตอร์ Amazon ES
เพื่อสร้างคลัสเตอร์ Amazon ES
- ลงชื่อเข้าใช้ AWS Management Console และเปิดคอนโซล Amazon Elasticsearch Service ที่ https://console.aws.amazon.com/es/
- เลือก สร้างโดเมนใหม่และเลือกประเภทการปรับใช้ ในคอนโซล Amazon ES.
- ภายใต้เวอร์ชันให้ใช้ค่าเริ่มต้นของฟิลด์เวอร์ชัน Elasticsearch
- เลือกถัดไป
- พิมพ์ชื่อโดเมนการค้นหา Elastic ของคุณในไฟล์ กำหนดค่าคลัสเตอร์ หน้าภายใต้ กำหนดค่าโดเมน
- ในหน้ากำหนดค่าคลัสเตอร์เลือกตัวเลือกต่อไปนี้ภายใต้อินสแตนซ์ข้อมูล
- ประเภทอินสแตนซ์ - เลือก t2.micro.elasticsearch (มีสิทธิ์ระดับฟรี)
- จำนวนอินสแตนซ์ - หนึ่ง
- ภายใต้อินสแตนซ์มาสเตอร์เฉพาะ
- เปิดใช้งานต้นแบบเฉพาะ - อย่าเปิดใช้งานตัวเลือกนี้
- เปิดใช้งานการรับรู้โซน - อย่าเปิดใช้งานตัวเลือกนี้.
- ภายใต้การกำหนดค่าที่เก็บข้อมูลให้เลือกตัวเลือกต่อไปนี้
- ประเภทการจัดเก็บ - เลือก EBS สำหรับการตั้งค่า EBS ให้เลือกประเภทโวลุ่ม EBS ของ General Purpose (SSD) และขนาดโวลุ่ม EBS& thinspจาก 10.
- ภายใต้การเข้ารหัส - อย่าเปิดใช้งานตัวเลือกนี้
- ภายใต้การกำหนดค่าสแนปชอต
- ชั่วโมงเริ่มต้นสแนปชอตอัตโนมัติ - เลือกสแนปช็อตอัตโนมัติชั่วโมงเริ่มต้น 00:00 UTC (ค่าเริ่มต้น)
- เลือกถัดไป
- ภายใต้การกำหนดค่าเครือข่ายเลือกการเข้าถึง VPC และเลือกรายละเอียดตามที่ VPC ของคุณแสดงไว้ด้านล่างภายใต้การพิสูจน์ตัวตน Kibana: - อย่าเปิดใช้งานตัวเลือกนี้
- ในการตั้งค่านโยบายการเข้าถึงให้เลือกอนุญาตการเข้าถึงโดเมนแบบเปิดหมายเหตุ: - ในการผลิตคุณควร จำกัด การเข้าถึงเฉพาะที่อยู่ IP หรือช่วง
- เลือกถัดไป
- ในหน้าตรวจสอบตรวจสอบการตั้งค่าของคุณจากนั้นเลือกยืนยันและสร้าง
หมายเหตุ: คลัสเตอร์จะใช้เวลาถึงสิบนาทีในการปรับใช้ จด URL Kibana ของคุณเมื่อคุณคลิกโดเมนการค้นหาแบบยืดหยุ่นที่สร้างขึ้น
ขั้นตอนที่ 3: ปรับใช้ Fluentd Logging Agent บนคลัสเตอร์ Kubernetes
Fluentd เป็นตัวรวบรวมข้อมูลแบบโอเพนซอร์สซึ่งช่วยให้คุณสามารถรวมการรวบรวมและการใช้ข้อมูลเพื่อการใช้งานและทำความเข้าใจข้อมูลได้ดีขึ้น ในกรณีนี้เราจะปรับใช้ Fluentd logging บนคลัสเตอร์ Kubernetes ซึ่งจะรวบรวมไฟล์บันทึกและส่งไปยัง Amazon Elastic Search
เราจะสร้าง ClusterRole ซึ่งให้สิทธิ์บนพ็อดและเนมสเปซออบเจ็กต์เพื่อสร้างรายการและดูคำขอไปยังคลัสเตอร์
ขั้นแรกเราต้องกำหนดค่าสิทธิ์ RBAC (การควบคุมการเข้าถึงตามบทบาท) เพื่อให้ Fluentd สามารถเข้าถึงส่วนประกอบที่เหมาะสมได้
1.fluentd-rbac.yaml:
apiVersion: v1 ชนิด: ServiceAccount metadata: name: fluentd namespace: kube-system --- apiVersion: rbac.authorization.k8s.io/v1beta1 ชนิด: ClusterRole metadata: name: fluentd namespace: kube-system rules: - apiGroups: - ' 'resources: - pods - namespaces verbs: - get - list - watch --- kind: ClusterRoleBinding apiVersion: rbac.authorization.k8s.io/v1beta1 metadata: name: fluentd roleRef: kind: ClusterRole name: fluentd apiGroup: rbac.authorization .k8s.io subject: - kind: ServiceAccount name: fluentd namespace: kube-system
สร้าง: $ kubectl สร้าง -f kubernetes / fluentd-rbac.yaml
ตอนนี้เราสามารถสร้าง DaemonSet
2. fluentd-daemonset.yaml
apiVersion: extensions / v1beta1 ชนิด: DaemonSet metadata: name: fluentd namespace: kube-system labels: k8s-app: fluentd-logging version: v1 kubernetes.io/cluster-service: 'true' spec: template: metadata: label: k8s -app: fluentd-logging version: v1 kubernetes.io/cluster-service: 'true' spec: serviceAccount: fluentd serviceAccountName: fluentd tolerations: - key: node-role.kubernetes.io/master effect: NoSchedule container: - name: รูปภาพ fluentd: fluent / fluentd-kubernetes-daemonset: v1.3-debian-elasticsearch env: - name: FLUENT_ELASTICSEARCH_HOST ค่า: 'elasticsearch.logging' - ชื่อ: FLUENT_ELASTICSEARCH_PORT ค่า: '9200' - ชื่อ: ค่า FLUENT_ELASTICSE - http ' ชื่อ: ค่า FLUENT_UID: ทรัพยากร '0': ข้อ จำกัด : หน่วยความจำ: คำขอ 200Mi: cpu: หน่วยความจำ 100m: 200Mi volumeMounts: - name: varlog mountPath: / var / log - name: varlibdockercontainers mountPath: / var / lib / docker / container readOnly : true terminationGracePeriodSeconds: 30 วอลุ่ม: - name: varlog hostPath: path: / var / log - name: varlibdockercontainers hostPath: path: / var / lib / docker / container
อย่าลืมกำหนด FLUENT_ELASTICSEARCH_HOST & FLUENT_ELASTICSEARCH_PORT ตามสภาพแวดล้อมการค้นหาแบบยืดหยุ่นของคุณ
ปรับใช้:
วิธีการใช้วิธีนามธรรมใน java
$ kubectl สร้าง -f kubernetes / fluentd-daemonset.yaml
ตรวจสอบความถูกต้องของบันทึก
บันทึก $ kubectl ได้อย่างคล่องแคล่วd-lwbt6 -n kube-system | การเชื่อมต่อ grep
คุณจะเห็นว่า Fluentd เชื่อมต่อกับ Elasticsearch ภายในบันทึก:
ขั้นตอนที่ 4: แสดงภาพข้อมูล kubernetes ใน Kibana
- เชื่อมต่อกับ URL แดชบอร์ด kibana เพื่อรับจากคอนโซล Amazon ES
- หากต้องการดูบันทึกที่ Fluentd รวบรวมไว้ใน Kibana ให้คลิก 'การจัดการ' จากนั้นเลือก 'รูปแบบดัชนี' ภายใต้ 'Kibana'
- เลือกรูปแบบดัชนีเริ่มต้น (logstash- *)
- คลิกขั้นตอนถัดไปและตั้งค่า“ ชื่อช่องตัวกรองเวลา” (@timestamp) แล้วเลือกสร้างรูปแบบดัชนี
- คลิกค้นพบเพื่อดูบันทึกแอปพลิเคชันของคุณ
- คลิกแสดงภาพและเลือกสร้างการแสดงภาพและเลือกพาย กรอกข้อมูลในฟิลด์ต่อไปนี้ตามที่แสดงด้านล่าง
- เลือก Logstash- * index แล้วคลิกแยกชิ้น
- การรวม - เงื่อนไขที่สำคัญ
- ฟิลด์ = Kubernetes.pod_name.keyword
- ขนาด - 10
7. และใช้การเปลี่ยนแปลง
แค่นั้นแหละ! นี่คือวิธีที่คุณจะเห็นภาพ Kubernetes Pod ที่สร้างใน Kibana
สรุป :
การตรวจสอบโดยการวิเคราะห์บันทึกเป็นองค์ประกอบสำคัญของการปรับใช้แอปพลิเคชันใด ๆ คุณสามารถรวบรวมและรวมบันทึกระหว่างคลัสเตอร์ของคุณใน Kubernetes เพื่อตรวจสอบคลัสเตอร์ทั้งหมดจากแดชบอร์ดเดียว ในตัวอย่างของเราเราได้เห็นการดำเนินการที่คล่องแคล่วเป็นสื่อกลางระหว่างคลัสเตอร์ kubernetes และ Amazon ES Fluentd รวมการรวบรวมบันทึกและการรวมเข้าด้วยกันและส่งบันทึกไปยัง Amazon ES สำหรับการวิเคราะห์บันทึกและการแสดงข้อมูลด้วย kibana
ตัวอย่างข้างต้นแสดงวิธีเพิ่ม AWS Elastic search logging และ kibana Monitoring ไปยัง kubernetes cluster โดยใช้ fluentd
หากคุณพบว่าบล็อก Kubernetes นี้เกี่ยวข้องโปรดดูที่ โดย Edureka บริษัท การเรียนรู้ออนไลน์ที่เชื่อถือได้ซึ่งมีเครือข่ายผู้เรียนที่พึงพอใจมากกว่า 250,000 คนกระจายอยู่ทั่วโลก
มีคำถามสำหรับเรา? โปรดระบุไว้ในส่วนความคิดเห็นแล้วเราจะติดต่อกลับไป