कुबेरनेट्स - सेवा

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

एक सेवा Kubernetes में एक REST ऑब्जेक्ट है जिसकी परिभाषा को Kubernetes apiServer पर Kubernetes मास्टर पर एक नया उदाहरण बनाने के लिए पोस्ट किया जा सकता है।

चयनकर्ता के बिना सेवा

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
   - port: 8080
   targetPort: 31999

उपरोक्त कॉन्फ़िगरेशन Tutorial_point_service नाम के साथ एक सेवा बनाएगा।

सेवा विन्यास फाइल चयनकर्ता के साथ

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   selector:
      application: "My Application" -------------------> (Selector)
   ports:
   - port: 8080
   targetPort: 31999

इस उदाहरण में, हमारे पास एक चयनकर्ता है; इसलिए ट्रैफ़िक स्थानांतरित करने के लिए, हमें मैन्युअल रूप से एक समापन बिंदु बनाने की आवश्यकता है।

apiVersion: v1
kind: Endpoints
metadata:
   name: Tutorial_point_service
subnets:
   address:
      "ip": "192.168.168.40" -------------------> (Selector)
   ports:
      - port: 8080

उपरोक्त कोड में, हमने एक एंडपॉइंट बनाया है जो ट्रैफ़िक को "192.168.168.40:8080" के रूप में परिभाषित पॉइंट पर ले जाएगा।

मल्टी-पोर्ट सर्विस क्रिएशन

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   selector:
      application: “My Application” -------------------> (Selector)
   ClusterIP: 10.3.0.12
   ports:
      -name: http
      protocol: TCP
      port: 80
      targetPort: 31999
   -name:https
      Protocol: TCP
      Port: 443
      targetPort: 31998

सेवाओं के प्रकार

ClusterIP- यह क्लस्टर के भीतर सेवा को प्रतिबंधित करने में मदद करता है। यह परिभाषित कुबेरनेट क्लस्टर के भीतर सेवा को उजागर करता है।

spec:
   type: NodePort
   ports:
   - port: 8080
      nodePort: 31999
      name: NodeportService

NodePort- यह तैनात नोड पर एक स्थिर पोर्ट पर सेवा को उजागर करेगा। एClusterIP सेवा, जो करने के लिए NodePortसेवा मार्ग, स्वचालित रूप से बनाया जाता है। सेवा का उपयोग क्लस्टर के बाहर से पहुँचा जा सकता हैNodeIP:nodePort

spec:
   ports:
   - port: 8080
      nodePort: 31999
      name: NodeportService
      clusterIP: 10.20.30.40

Load Balancer - इसमें क्लाउड प्रोवाइडर्स लोड बैलेंसर का इस्तेमाल किया गया है। NodePort तथा ClusterIP सेवाओं को स्वचालित रूप से बनाया जाता है जिससे बाहरी लोड बैलेंसर रूट हो जाएगा।

एक पूर्ण सेवा yamlनोड पोर्ट के रूप में सेवा प्रकार के साथ फ़ाइल। खुद को बनाने की कोशिश करें।

apiVersion: v1
kind: Service
metadata:
   name: appname
   labels:
      k8s-app: appname
spec:
   type: NodePort
   ports:
   - port: 8080
      nodePort: 31999
      name: omninginx
   selector:
      k8s-app: appname
      component: nginx
      env: env_name