时间:2022-04-02来源:www.pcxitongcheng.com作者:电脑系统城
关于 Service,读者可以查看官方文档的资料:https://kubernetes.io/zh/docs/concepts/services-networking/service/
Service 是 k8s 中为多个 pod 公开网络服务的抽象方法。在 k8s 中,每个 pod 都有自己的 ip 地址,而且 Service 可以为一组 pod 提供相同的 DNS ,使得多个 pod 之间可以相互通讯,k8s 可以在这些 pod 之间进行负载均衡。
查询 pod:
| 1 | kubectl get pods |
| 1 2 3 4 |
NAME READY STATUS RESTARTS AGEnginx-585449566-d2fdc 1/1 Running 0 4h14mnginx-585449566-krsch 1/1 Running 0 67mnginx-585449566-l2j6h 1/1 Running 0 67m |
查看 Service:
| 1 | kubectl get services |
| 1 2 3 |
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEkubernetes ClusterIP 10.96.0.1 <none> 443/TCP 29hnginx ClusterIP 10.101.245.225 <none> 80/TCP 4h19m |
kubectl exec {pod名称} {要执行的命令} 可以在 pod 中执行某个命令,这里我们可以打印某个 pod 的环境变量。
| 1 2 3 |
kubectl exec nginx-585449566-d2fdc -- pritenv# 或者# kubectl exec nginx-585449566-d2fdc env |
| 1 2 3 4 5 6 7 8 |
... ...KUBERNETES_PORT=tcp://10.96.0.1:443KUBERNETES_PORT_443_TCP=tcp://10.96.0.1:443KUBERNETES_PORT_443_TCP_PROTO=tcpKUBERNETES_PORT_443_TCP_PORT=443KUBERNETES_PORT_443_TCP_ADDR=10.96.0.1NGINX_VERSION=1.19.10... ... |
k8s 中可以将一个 Service 暴露到集群外部,外界可以通过 ip 访问这个 Service。Service 有个 ServiceType ,允许我们指定如何暴露服务。
Type 有三种类型,其取值说明如下:
ClusterIP
通过集群内部 IP 暴露服务,也就是说只能在集群内部访问,ClusterIP 是 ServiceType 的默认值。
NodePort
通过每个节点上的 IP 和静态端口(NodePort)暴露服务。由于其是节点上的 ,所以具有通过集群外部访问这个服务。
LoadBalancer
使用云提供商的负载均衡器向外部暴露服务。 外部负载均衡器可以将流量路由到自动创建的 NodePort 服务和 ClusterIP 服务上。
ExternalName
通过返回 CNAME 和对应值,可以将服务映射到 externalName 字段的内容(例如,foo.bar.example.com)。

我们删除之前 Deployment 部署 nginx 时,通过 expose 创建的 Service。
| 1 | kubectl delete service nginx |
然后重新创建 service。
| 1 | kubectl expose deployment nginx --type=LoadBalancer |
查询 Service(kubectl get services):
| 1 2 3 |
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEkubernetes ClusterIP 10.96.0.1 <none> 443/TCP 29hnginx LoadBalancer 10.97.249.37 <pending> 80:31036/TCP 30s |
这里我们说一下这个端口的一些说明。
Service 是针对一个 Pod 或多个 Pod 起效,它为一组 pod 暴露相同的端口。也就是说,同一个 Service 中的 pod 不能分别设置不同的 端口。而且前面我们的一个 Service 中,是为一个 nginx 创建 Deployment ,并且设置副本集,所以他们的 端口是一致的。
Service 不会直接把 pod 暴露的 端口映射到公网,Service 默认在 30000-32767 之间为我们映射端口。所以笔者服务器上,是 310361(外网) 映射了 80(内网)。
这时已经可以直接通过外网访问 Service 中的服务了。如果你不知道服务器的公网 ip,可以通过命令查询:
| 1 | curl ifconfig.io |
然后访问 http://x.x.x.x:31036 即可。
当使用 LoadBalancer 暴露服务到集群外部网络时,我们访问的实际上是 Service,而不是具体的某个 pod,然后 Service 会将流量重定向到后端 pod 中。这个要看实际环境和云服务商的支持。
kubectl scale 命令可以扩容或缩容 Deployment、ReplicaSet、Replication Controller 或 Job 中Pod数量。在上一篇文件中中我们已经使用到。这里我们继续使用这个命令来伸缩 nginx 副本的数量,然后观察外部网络访问 Service 时的结果。
现在将我们的 nginx 副本数量设置为 0。
| 1 | kubectl scale deployment nginx --replicas=0 |
再访问 公网的 31036 端口(具体端口看你查询出来的),发现无法访问了,因为 pod 数量为 0 ,Service 找不到 pod 来提供服务。
如果我们把 ReplicaSet 数量设置为 1 或以上,则又可以继续访问了。
| 1 | kubectl scale deployment nginx --replicas=2 |
到此为止,我们的学习已经完成一个小阶段,能够创建集群、加入新的 Node、部署 pod 以及暴露公网 ip,允许外部访问,还可以提供多副本以负载均衡。接下来我们总结一下学习到的工具、命令,后续的学习会在这些基础之上开展。
kubeadm
kubeadm init、kubeadm join 创建集群和使节点加入集群。
kubectl
kubectl 原理是请求 apiserver 完成某些操作,日常操作中,最常用的就是 kubectl。
kubectl create {对象} ,创建 deployment、job 等对象。
kubectl apply -f 应用 yaml 文件,完成某些操作。
kubectl get {对象} 查询对象。
kubectl scale {对象} 伸缩对象数量(ReplicaSet)。
kubectl expose 创建 Service。
kubectl describe 获取对象详细的信息。
kubectl exec 在对象中执行命令,例如 pod。
到此这篇关于配置Kubernetes外网访问集群的文章就介绍到这了。
2024-07-07
myeclipse怎么导入tomcat教程2024-07-07
myeclipse如何启动tomcat2024-07-07
myeclipse如何绑定tomcat上线了一个小的预约程序,配置通过Nginx进行访问入口,默认的日志是没有请求时间的,因此需要配置一下,将每一次的请求的访问响应时间记录出来,备查与优化使用....
2023-03-17