32、k8s-service类型-第三种-NodePort(常用)-外部访问
概念:前面的两种service类型(Cluster IP和HeadLiness)只能集群内部才可以访问、如果希望service暴露给外部使用、那么就要使用到另外一种类型的service、
NodePort类型:NodePort的工作原理其实就是 将service的端口映射到Node节点的一个端口上、 然后就可以通过nodeIP:NodePort来访问service了
测试
1、创建nodeport类型的yaml文件:
----------------------------------------------------
apiVersion: v1
kind: Service
metadata:
name: service-nodeport
namespace: dev
spec:
selector:
app: nginx-pod
type: NodePort #service的类型
ports:
- port: 80 #service端口
nodePort: 30002 #指定绑定的node端口(默认的取值范围是:30000-32767),如果不指定、会默认在这个范围内自动分配
targetPort: 80 #pod端口
----------------------------------------------------------------------------------------------------
2、创建 nodeport: kubectl create -f service-nodeport.yaml
3、查看nodeport service:kubectl get svc service-nodeport -ndev
--------------------------------------------------------------------
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service-nodeport NodePort 10.106.242.94 <none> 80:30002/TCP 46s
#10.106.242.94:80这个ip+端口80 只用于集群内部访问、(CLUSTER-IP是service自动分配的ip)
#外部访问用本机IP:30002即可(说明:本机ip是虚拟机的ip192.168.177.160)
------------------------------------------------------------------------------------------------
4、浏览器访问:192.168.177.160:30002