• Kubernetes - Ingress HTTP 负载搭建部署解决方案(新版本v1.21+)


    在看这一篇之前,如果不了解 Ingress 在 K8s 当中的职责,建议看之前的一篇针对旧版本 Ingress 的部署搭建,在开头会提到它的一些简介Kubernetes - Ingress HTTP 负载搭建部署解决方案_放羊的牧码的博客-CSDN博客

     开始表演

    1、kubeasz 一键安装部署 Ingress

    kubectl apply -f https://raw.githubusercontent.com/qist/k8s/main/k8s-yaml/ingress-nginx/ingress-nginx-ipv4.yaml

    2、安装我们的服务应用 Service 对应的 Ingress

    1. # nginx-ingress-controller-app-service.yaml
    2. apiVersion: networking.k8s.io/v1
    3. kind: Ingress
    4. metadata:
    5. name: ingress-app
    6. namespace: default # 跟我们的应用 pod 在一个 namespace 即可
    7. annotations:
    8. kubernetes.io/ingress.class: "nginx"
    9. spec:
    10. rules:
    11. - host: api.app.com # 外部可以访问的域名
    12. http:
    13. paths:
    14. - path: /
    15. pathType: Prefix
    16. backend:
    17. service:
    18. name: app-server # app service name
    19. port:
    20. number: 38080 # app service port
    kubectl apply -f nginx-ingress-controller-app-service.yaml

    3、稍做分析

    • 附:app service yaml
    1. kind: Service
    2. apiVersion: v1
    3. metadata:
    4. name: app-server
    5. namespace: default
    6. uid: e462e330-ea68-41ea-b351-71680ea4c685
    7. resourceVersion: '576970'
    8. creationTimestamp: '2023-10-26T11:07:01Z'
    9. annotations:
    10. kubectl.kubernetes.io/last-applied-configuration: >
    11. {"apiVersion":"v1","kind":"Service","metadata":{"annotations":{},"name":"app-server","namespace":"default"},"spec":{"ports":[{"nodePort":38080,"port":38080,"protocol":"TCP","targetPort":38080}],"selector":{"app":"app-server"},"type":"NodePort"}}
    12. managedFields:
    13. - manager: kubectl-client-side-apply
    14. operation: Update
    15. apiVersion: v1
    16. time: '2023-10-26T11:07:01Z'
    17. fieldsType: FieldsV1
    18. fieldsV1:
    19. f:metadata:
    20. f:annotations:
    21. .: {}
    22. f:kubectl.kubernetes.io/last-applied-configuration: {}
    23. f:spec:
    24. f:externalTrafficPolicy: {}
    25. f:internalTrafficPolicy: {}
    26. f:ports: {}
    27. f:selector: {}
    28. f:sessionAffinity: {}
    29. - manager: dashboard
    30. operation: Update
    31. apiVersion: v1
    32. time: '2023-10-28T10:28:57Z'
    33. fieldsType: FieldsV1
    34. fieldsV1:
    35. f:spec:
    36. f:ports:
    37. k:{"port":12345,"protocol":"TCP"}:
    38. .: {}
    39. f:port: {}
    40. f:protocol: {}
    41. f:targetPort: {}
    42. f:type: {}
    43. spec:
    44. ports:
    45. - protocol: TCP
    46. port: 12345
    47. targetPort: 38080
    48. selector:
    49. app: app-server
    50. clusterIP: 10.68.184.146
    51. clusterIPs:
    52. - 10.68.184.146
    53. type: ClusterIP
    54. sessionAffinity: None
    55. ipFamilies:
    56. - IPv4
    57. ipFamilyPolicy: SingleStack
    58. internalTrafficPolicy: Cluster
    59. status:
    60. loadBalancer: {}
    • 重点关注 spec.ports 部分,service 这里的 targetPort = app port,port =  ingress port-number
    • 最后,可以用 api.app.com:80 访问即可命中这个程序~ 为什么这里就可以用 80 来访问呢?因为 Ingress-Controller 一键安装完后默认开放了 80、443、8443 端口噢!

    彩蛋

    • 结论一、Service 中 NodePort 方式和 Ingress 方式可同时存在并依然有效
    • 结论二、在结论一的基础上,可以使用 NodePort 的方式设置 nodePort 端口,外部可直接用该 nodePort 来访问 Pod
    • 结论三、如果是 NodePort 方式,但不设置 nodePort,系统会随机给它生成一个对外端口号
    1. # 通过命令查询随机生成的端口号
    2. kubectl get svc

    • 如果用 Ingress 技术来作为外部想用 port 12345 来访问 pod 该如何修改配置呢?!前提 38080 不变的情况下~欢迎评论哈!
  • 相关阅读:
    Redis五种基本数据类型-Hash
    如何在ADS中综合耦合矩阵
    数据结构-二叉树的前、中、后序遍历
    OpenFeign
    智云通CRM:读懂客户的五种“成交信号”,恰到好处地收单?
    Git基本操作(2)
    Spring系列七:JDK 动态代理和 CGLIB 代理
    使用北鲲云在AWS上运行基因分析HPC任务
    I/O复用--浅谈epoll
    凉鞋的 Unity 笔记 202. 变量概述与简介
  • 原文地址:https://blog.csdn.net/Dream_Weave/article/details/134095304