• k8s实战入门——Service


    Service

    通过Deployment来创建一组Pod来提供具有高可用性的服务。

    虽然每个Pod都会分配一个单独的Pod IP,然而却存在如下两问题:

    - Pod IP 会随着Pod的重建产生变化
    - Pod IP 仅仅是集群内可见的虚拟IP,外部无法访问

    这样对于访问这个服务带来了难度。因此,kubernetes设计了Service来解决这个问题。

    Service可以看作是一组同类Pod对外的访问接口。借助Service,应用可以方便地实现服务发现和负载均衡。

    创建集群内部可访问的Service

    暴露Service

    kubectl expose deployment xxx --name=服务名 --type=ClusterIP --port=暴露的端口 --target-port=指向集群中的Pod的端口 [-n 命名空间]
    注:ClusterIP是默认type类型的,即不指定也是ClusterIP
    --port=暴露的端口是service的IP端口
    
    [root@master ~]# kubectl expose deploy nginx --name=svc-nginx --type=ClusterIP --port=80 --target-port=80 -n dev

     查看Service

    kubectl get service [-n 命名空间] [-o wide]
    
    [root@master ~]# kubectl get svc svc-nginx -n dev -o wide
    
    # 这里产生了一个CLUSTER-IP,这就是service的IP,在Service的生命周期中,这个地址是不会变动的
    # 可以通过这个IP访问当前service对应的Pod
    
    [root@master ~]# curl 10.102.145.225:80
    #若端口是80,则可省略

    创建集群外部也可访问的Service

    # 上面创建的Service的type类型为ClusterIP,这个ip地址只用集群内部可访问
    # 如果需要创建外部也可以访问的Service,需要修改type为NodePort
    
    kubectl expose deployment xxx --name=服务名 --type=NodePort --port=暴露的端口 --target-port=指向集群中的Pod的端口 [-n 命名空间]
    
    # 会产生一个外部也可以访问的Service
    
    [root@master ~]# kubectl expose deploy nginx --name=svc-nginx2 --type=NodePort --port=80 --target-port=80 -n dev
    
    [root@master ~]# kubectl get svc -n dev -o wide
    
    [root@master ~]# curl 192.168.1.50:31458
    
    # 接下来就可以通过集群外的主机访问 节点IP: 31458访问服务了
    # 例如在的电脑主机上通过浏览器访问下面的地址

    删除Service

    kubectl delete service xxx [-n 命名空间]
    
    [root@master ~]# kubectl delete svc svc-nginx -n dev

    yaml配置方式

    创建一个svc-nginx.yaml,内容如下:

    apiVersion: v1
    kind: Service
    metadata:
      name: svc-nginx        #svc的名字
      namespace: dev
    spec:
      clusterIP: 10.109.179.231 #指定svc的内网ip,若不写则默认随机分配
      ports:
      - port: 80
        protocol: TCP
        targetPort: 80
      selector:
        run: nginx
      type: ClusterIP      #默认是ClusterIP,可不写

    然后就可以执行对应的创建和删除命令了:

    创建
    [root@master ~]# kubectl create svc svc-nginx -n dev
    
    删除
    [root@master ~]# kubectl delete svc svc-nginx -n dev
    
    删除所有
    [root@master ~]# kubectl delete svc --all -n dev

    好了, 以上是本文所有内容,希望对大家有所帮助,也希望大家对码农之家多多支持,你们的支持是我创作的动力!祝大家生活愉快! 
    

  • 相关阅读:
    面试中经常问到的几个问题,快来看看能答对几道吧
    iOS app 的开发要准备哪些图标图片?
    【Mybatis】基于Mybatis插件+注解,实现敏感数据自动加解密
    Android WebView中文件上传功能的实现
    注解方式优雅的实现 Redisson 分布式锁
    JVM内存模型介绍
    MySQL之MVCC
    Java学习路线图,全套Java基础视频教程
    系列文章|云原生时代下微服务架构进阶之路 - Spring Boot
    【DevPress】V2.4.1版本发布,增加抽奖组件
  • 原文地址:https://blog.csdn.net/wuxiaopengnihao1/article/details/127786450