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) AGEtest-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 imgw1servisin 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