Alibaba Cloud Provider简介

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: Alibaba Cloud Provider简介 CloudProvider 提供kubernetes与云厂商基础服务的对接能力,由 cloud-controller-manager组件实现。 通过这个组件,可以让用户在创建k8s LoadBalancer 类型的service的时候自动的为用户创.

Alibaba Cloud Provider

Alibaba Cloud Provider简介

CloudProvider 提供kubernetes与云厂商基础服务的对接能力,由 cloud-controller-manager组件实现

通过这个组件,可以让用户在创建k8s LoadBalancer 类型的service的时候自动的为用户创建一个阿里云SLB,同时动态的绑定与解绑SLB后端,并且提供了丰富的配置允许用户自定义生成的LoadBalancer.

参考ReleaseNotes.

基本使用方式 cloudprovider通过service上的annotation来控制创建Type: LoadBalancer类型的service时的行为。一个基本的annotation示例如下:

apiVersion: v1
kind: Service
metadata:
  annotations:
    # 这里填写相应的annotation, 用例
    service.beta.kubernetes.io/alicloud-loadbalancer-id: lb-bp1hfycf39bbeb019pg7m
  name: nginx
  namespace: default
spec:
  ports:
  - name: web
    port: 443
    protocol: TCP
    targetPort: 443
  type: LoadBalancer

>> 注意事项:

  • 如果您的集群的cloud-controller-manager版本大于等于v1.9.3,对于指定已有SLB的时候,系统默认不再为该SLB处理监听,用户需要手动配置该SLB的监听规则。

执行以下命令,可查看cloud-controller-manager的版本。

root@master # kubectl get po -n kube-system -o yaml|grep image:|grep cloud-con|uniq

image: registry-vpc.cn-....-controller-manager-amd64:v1.9.3

创建LoadBalancer的正确姿势

前置条件。

  • 一个可用的阿里云容器服务创建的集群。参考
  • 如何通过kubectl 连接到集群。参考
  • 创建一个普通的nginx应用。参考 ,后面的示例以改nginx应用为前提。

>> 注意

  • 保存以下yaml为svc.1.yaml , 然后使用 kubectl apply -f svc.1.yaml的方式来创建service.

1. 创建一个公网类型的负载均衡

apiVersion: v1
kind: Service
metadata:
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

2. 创建一个私网类型的负载均衡

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-address-type: "intranet"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

3. 创建HTTP类型的负载均衡

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-protocol-port: "http:80"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

4. 创建HTTPS类型的负载均衡

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-protocol-port: "https:443"
    service.beta.kubernetes.io/alicloud-loadbalancer-cert-id: ${YOUR_CERT_ID}
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

>> 说明:

  • 创建https类型的负载均衡需要您提供一个证书ID,如果还没有证书,请前往SLB控制台创建一个。

5. 限制负载均衡的带宽。

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-bandwidth: "100"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

>> 说明:

  • 只限制负载均衡的带宽。所有listener 共享该负载均衡的带宽。参考共享实例带宽

6. 指定负载均衡规格

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-spec: "slb.s1.small"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

7. 绑定已有的负载均衡到Service

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-id: "${YOUR_LOADBALANCER_ID}"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

>> 说明:

  • 默认情况下,绑定已有SLB的时候CloudProvider只会为您的绑定和解绑SLB后端Server,不会处理监听。您需要指定service.beta.kubernetes.io/alicloud-loadbalancer-force-override-listeners: "true"来强制覆盖监听。注意这会删除您已有SLB上的非预期的监听。

8. 绑定已有负载均衡,并强制覆盖已有监听

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-id: "${YOUR_LOADBALANCER_ID}"
    service.beta.kubernetes.io/alicloud-loadbalancer-force-override-listeners: "true"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

9. 让SLB挂载具有指定label的worker节点作为后端server

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-backend-label: "failure-domain.beta.kubernetes.io/zone:ap-southeast-5a"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 多个label以逗号分隔。 "k1:v1,k2:v2"
  • 多个label之间是and的语义。

10. 为TCP类型的SLB配置会话保持SessionSticky

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-persistence-timeout: "1800"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 443
    protocol: TCP
    targetPort: 443
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 该参数仅对TCP监听起作用。
  • 如果service配置了多个TCP的监听端口,该会话保持默认应用到所有TCP监听端口

11. 为HTTP&HTTPS类型的SLB配置会话保持SessionSticky(insert cookie)

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session: "on"
    service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session-type: "insert"
    service.beta.kubernetes.io/alicloud-loadbalancer-cookie-timeout: "1800"
    service.beta.kubernetes.io/alicloud-loadbalancer-protocol-port: "http:80"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 仅HTTP & HTTPS。
  • 会话保持类型为insert,植入Cookie.
  • 如果service配置了多个HTTP或者HTTPS的监听端口,该会话保持默认应用到所有HTTP&HTTPS监听端口

12. 为HTTP&HTTPS类型的SLB配置会话保持SessionSticky(server cookie)

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session: "on"
    service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session-type: "server"
    service.beta.kubernetes.io/alicloud-loadbalancer-cookie: "${YOUR_COOKIE}"
    service.beta.kubernetes.io/alicloud-loadbalancer-protocol-port: "http:80"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 仅HTTP & HTTPS。
  • 会话保持类型为server, 重写Cookie.
  • 如果service配置了多个HTTP或者HTTPS的监听端口,该会话保持默认应用到所有HTTP&HTTPS监听端口

13. 创建的SLB时,指定其主备可用区

apiVersion: v1
kind: Service
metadata:
  annotations:
    service.beta.kubernetes.io/alicloud-loadbalancer-master-zoneid: "ap-southeast-5a"
    service.beta.kubernetes.io/alicloud-loadbalancer-slave-zoneid: "ap-southeast-5a"
  name: nginx
  namespace: default
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 某些region的SLB不支持主备可用区,如ap-southeast-5
  • 一旦创建,不支持修改主备可用区。

13. 指定SLB仅挂载Pod所在节点作为后端Server

apiVersion: v1
kind: Service
metadata:
  name: nginx
  namespace: default
spec:
  externalTrafficPolicy: Local
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    run: nginx
  type: LoadBalancer

>> 注意

  • 某些region的SLB不支持主备可用区,如ap-southeast-5
  • 一旦创建,不支持修改主备可用区。

附件:可用的Annotation参数及其说明

>> 注意

  • 所有的annotation均为字符类型,使用双引号括起来。
可用注释(annotation) 描述 默认值
service.beta.kubernetes.io/alicloud-loadbalancer-protocol-port 多个值之间由逗号分隔,
比如:https:443,http:80
service.beta.kubernetes.io/alicloud-loadbalancer-address-type 创建公网类型或者私网类型的SLB,
取值可以是 internet 或者 intranet
"internet"
service.beta.kubernetes.io/alicloud-loadbalancer-slb-network-type 负载均衡的网络类型,
取值可以是 classic 或者 vpc
"classic"
service.beta.kubernetes.io/alicloud-loadbalancer-charge-type 取值可以是 paybytraffic 或者 paybybandwidth "paybytraffic"
service.beta.kubernetes.io/alicloud-loadbalancer-id 指定已有负载均衡实例的 ID。
删除 service 时该 SLB 不会被删除。
service.beta.kubernetes.io/alicloud-loadbalancer-backend-label 通过 label 指定 SLB 后端挂哪些节点。
service.beta.kubernetes.io/alicloud-loadbalancer-spec SLB的规格。
slb.s1.small ,
slb.s2.small......
参考API
service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session 是否开启会话保持。
(仅对HTTP和HTTPS类型监听)
取值:on / off参考API
"off"
service.beta.kubernetes.io/alicloud-loadbalancer-sticky-session-type cookie的处理方式。
取值: insert:植入Cookie。
server:重写Cookie。
(当StickySession的值为on时,必须指定该参数)(仅对HTTP和HTTPS类型监听)参考API
service.beta.kubernetes.io/alicloud-loadbalancer-cookie-timeout Cookie超时时间。
取值: 1-86400(秒)
当StickySession为on且StickySessionType为insert时,该参数必选。参考API
service.beta.kubernetes.io/alicloud-loadbalancer-cookie 服务器上配置的Cookie。
长度为1-200个字符,只能包含ASCII英文字母和数字字符,
不能包含逗号、分号或空格,也不能以$开头。
当StickySession为on且StickySessionType为server时,该参数必选。参考API
service.beta.kubernetes.io/alicloud-loadbalancer-persistence-timeout 会话保持时间。
(仅对TCP监听)取值:0-3600(秒)
默认值为0,关闭会话保持。参考API
"0"
service.beta.kubernetes.io/alicloud-loadbalancer-force-override-listeners 当指定已有SLB的时候,是否强制覆盖该SLB的listener.
默认不覆盖
"false"
service.beta.kubernetes.io/alicloud-loadbalancer-region 负载均衡所在的地域
service.beta.kubernetes.io/alicloud-loadbalancer-bandwidth 负载均衡的带宽 “50”
service.beta.kubernetes.io/alicloud-loadbalancer-cert-id 阿里云上的认证 ID。您需要先上传证书 “”
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-flag 取值是 on 或者 off
1.默认为 off。
2.TCP 协议默认on, 且不可修改
off
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-type 参见 HealthChecktcp / http tcp
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-uri 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-connect-port 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-healthy-threshold 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-unhealthy-threshold 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-interval 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-connect-timeout 参见 HealthCheck
service.beta.kubernetes.io/alicloud-loadbalancer-health-check-timeout 参见 HealthCheck
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
消息中间件 Cloud Native 前端开发
Spring Cloud Alibaba 2021.0.1.0 版本发布啦
本次隆重发布的 Spring Cloud Alibaba 2021.0.1.0 版本在 Spring Cloud 2021.0.1、Spring Boot 2.6.3 的基础上对其中包括注册配置中心、分布式消息等在内的众多组件进行重大升级。
5383 9
Spring Cloud Alibaba 2021.0.1.0 版本发布啦
|
SpringCloudAlibaba Java 数据库连接
引入SpringCloud Alibaba(多配置集、GateWay)
引入SpringCloud Alibaba(多配置集、GateWay)
211 0
|
存储 消息中间件 监控
SpringCloud Alibaba常见组件
Spring Cloud Alibaba是一套基于Spring Cloud的微服务解决方案,它集成了多个常见的组件,每个组件都有特定的功能和用途。以下是Spring Cloud Alibaba的常见组件及其解决的问题:
2782 0
|
Java Nacos 微服务
Spring Cloud Alibaba - 23 Gateway初体验
Spring Cloud Alibaba - 23 Gateway初体验
140 0
|
Java Spring
Spring Cloud Alibaba - 27 Gateway源码解析
Spring Cloud Alibaba - 27 Gateway源码解析
159 0
|
消息中间件 Oracle Cloud Native
Spring Cloud Alibaba 2022.0.0.0 版本发布啦!
微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。
Spring Cloud Alibaba 2022.0.0.0 版本发布啦!
|
存储 消息中间件 SpringCloudAlibaba
SpringCloud Alibaba入门简介
why会出现SpringCloud alibaba
SpringCloud Alibaba入门简介
|
存储 消息中间件 SpringCloudAlibaba
SpringCloud Day10--SpringCloud Alibaba 入门简介
SpringCloud Day10--SpringCloud Alibaba 入门简介
SpringCloud Day10--SpringCloud Alibaba 入门简介
|
消息中间件 Cloud Native Java
Spring Cloud Alibaba 2.2.7 版本正式发布
Spring Cloud Alibaba 是由阿里巴巴(后文简称:阿里)中间件团队于 2018 年 7 月开源,为业界提供的一套基于阿里内部分布式技术的一站式微服务构建解决方案。基于 Spring Cloud 微服务框架标准,针对微服务架构中的服务注册与发现、分布式消息、服务限流降级以及分布式事务等核心模块,都提供了相应的面向业界的成熟解决方案
785 8
Spring Cloud Alibaba 2.2.7 版本正式发布