hostPort:
apiVersion: v1
kind: Pod
metadata:
name: tomcat
spec:
containers:
- name: tomcat
image: tomcat:8.5
ports:
- hostPort: 8081
containerPort: 8080
protocol: TCP
hostPort 类似docker -p 参数做的端口映射,将容器内端口映射到宿主机上(hostPort),
在k8s中,这是一种直接定义Pod网络的方式。
hostPort是直接将容器的端口与所调度的节点上的端口路由,这样用户就可以通过宿主机的IP加上来访问Pod了,需关注pod漂移策略。
port/nodeport/targetport
apiVersion: v1
kind: Service
metadata:
name: tomcat-svc
namespace: default
labels:
name: tomcat
spec:
type: NodePort
ports:
- port: 8080
targetPort: 8080
nodePort: 8081
selector:
name: tomcat
port
port是在Service IP中使用的,使用Service IP +Port就可以访问到服务
targetPort
targetPort 说的是Pod内的应用暴露的服务端口,Service IP+Port的访问会被代理到这个Target Port
nodePort
nodePort在kubenretes里是一个广泛应用的服务暴露方式。Kubernetes中的service默认情况下都是使用的ClusterIP这种类型,
这样的service会产生一个ClusterIP,这个IP只能在集群内部访问,要想让外部能够直接访问service,需要将service type修改为 nodePort。