19 Mayıs 2022 Perşembe

kubectl expose seçeneği - Deployment/Pod İçin Service Yaratır

Giriş
Açıklaması şöyle
Expose a resource as a new Kubernetes service.

Looks up a deployment, service, replica set, replication controller or pod by name and uses the selector for that resource as the selector for a new service on the specified port. [...]
Kullanım
kubectl expose deployment
kubectl expose pod

şeklinde kullanılır

1. deployment İçin
Tüm worker node'lar port açar. Pod'a erişmek için her hangi bir worker nodu'un IP adresini kullanılabilir.

Örnek - LoadBalancer
Şöyle yaparız
kubectl expose deployment your-deployment-name \ --type=LoadBalancer \ --port=80 \ --target-port=9092
Örnek - LoadBalancer
Şöyle yaparız
$ kubectl expose deployment 
  $( kubectl get deployment --selector="planetscale.com/component=vtgate" 
  -o=jsonpath="{.items..metadata.name}" ) 
  --type=LoadBalancer 
  --name=test-vtgate 
  --port 3306 
  --target-port 3306

$ kubectl get service test-vtgate
------
NAME         TYPE          CLUSTER-IP      EXTERNAL-IP      PORT(S)         AGE
test-vtgate  LoadBalancer  [cluster_ip]    [external_ip]    3306:32157/TCP  90s
2. pod İçin
Sadece tek bir pod'a port açar. Pod'a erişmek için bu pod'un çalıştığı worker node'un IP adresini kullanmak gerekir.

Örnek
Şöyle yaparız. nodePort numarası otomatik olarak veriliyor.
kubectl expose pod rabbitmq-0 --port=15672 --target-port=15672 --type=NodePort
Örnek - nodePort
Şöyle yaparız. Dahili 12340 portu dışarıya 30869 olarak açılır. nodePort numarası otomatik olarak veriliyor.
kubectl expose pod rlwy-proc-blue-6db5798f55-m2fmp --port=12340 --target-port=12340
  --type=NodePort --name imgw1
servisin detayları şöyledir. Burada IP: 172.30.135.252 yazıyor ama aslında bu IP adresi kullanılamaz. Bu pod'un çalıştığı worker node'un IP adresini kullanmak gerekir.
$  kubectl describe svc imgw1
Name:                     imgw1
Namespace:                rlwy-04
Labels:                   app=oce-rlwy-proc
                          chartColor=blue
                          ne=rlwy
                          pod-template-hash=6db5798f55
                          processingGroup=true
                          release=rlwy-04-oce-rlwy-proc-blue
                          runsCommManager=true
Annotations:              <none>
Selector:                 app=oce-rlwy-proc,...
Type:                     NodePort
IP Family Policy:         SingleStack
IP Families:              IPv4
IP:                       172.30.135.252
IPs:                      172.30.135.252
Port:                     <unset>  12340/TCP
TargetPort:               12340/TCP
NodePort:                 <unset>  30869/TCP
Endpoints:                10.130.4.19:12340
Session Affinity:         None
External Traffic Policy:  Cluster
Events:                   <none>
Örnek - LoadBalancer
Bunu denemedim ama tahminen şöyle yaparız. Böylece bir pod dış dünyaya açılır
kubectl expose pod rlwy-proc-blue-6db5798f55-m2fmp --port=12340 --target-port=12340
--type=LoadBalancer --name imgw1 -n rlwy-04
servise bakınca şöyledir
$ kubectl get svc
NAME   TYPE           CLUSTER-IP       EXTERNAL-IP      PORT(S)
imgw1  LoadBalancer   172.30.8.31      104.198.194.171  12340:31762/TCP
servisin detayları şöyledir
$ kubectl describe svc imgw1
Name:                     imgw1
Namespace:                rlwy-04
Labels:                   app=oce-rlwy-proc
                          chartColor=blue
                          ne=rlwy
                          pod-template-hash=6db5798f55
                          processingGroup=true
                          release=rlwy-04-oce-rlwy-proc-blue
                          runsCommManager=true
Annotations:              <none>
Selector:                 app=oce-rlwy-proc,chartColor=blue,...
Type:                     LoadBalancer
IP Family Policy:         SingleStack
IP Families:              IPv4
IP:                       172.30.8.31
IPs:                      172.30.8.31
LoadBalancer Ingress:     104.198.194.171
Port:                     <unset>  12340/TCP
TargetPort:               12340/TCP
NodePort:                 <unset>  31762/TCP
Endpoints:                10.130.4.19:12340
Session Affinity:         None
External Traffic Policy:  Cluster
Events:
  Type    Reason                Age    From                Message
  ----    ------                ----   ----                -------
  Normal  EnsuringLoadBalancer  8m4s   service-controller  Ensuring load balancer
  Normal  EnsuredLoadBalancer   7m31s  service-controller  Ensured load balancer
Örnek - LoadBalancer
Şöyle yaparız
kubectl expose pod odsa-spring --type LoadBalancer --port 80 --target-port 8080

Hiç yorum yok:

Yorum Gönder

Kubernetes kind: Cluster

Örnek Şöyle yaparız apiVersion: cluster.k8s.io/v1alpha1 kind: Cluster metadata: name: my-cluster spec: autoscaler: enabled: true ...