将自建Nginx Ingress迁移至云原生API网关

本文介绍如何通过白屏化迁移工具将自建Nginx Ingress迁移至云原生API网关。

前提条件

  • 已创建容器服务集群,且部署了Nginx Ingress Controller。

  • 已创建云原生API网关。如果您还没有云原生API网关,请参见创建网关实例

注意事项

  • 本文描述的迁移不是复制您的Ingress配置,而是让您的Ingress配置被云原生API网关 Ingress复用,实时监听已有的Ingress资源变化并解析。

  • 迁移过程中,如果您的Ingress配置发生变化,会同时反映在Nginx Ingress Controller和云原生API网关 Ingress。

  • 迁移完成之后,请不要随意删除线上正在使用的Ingress配置,迁移仅仅是让现有的Ingress配置以及未来新添加的Ingress配置被云原生API网关 Ingress监听并解析。

  • 迁移完成之后,现有的Ingress配置以及未来新添加的Ingress配置仍然需要关联之前使用的IngressClass。例如之前Ingressspec中的ingressClassNamenginx,那么在迁移之后,现有的Ingress配置以及未来新添加的Ingress配置的spec中的ingressClassName仍然需要是nginx。

迁移步骤说明

云原生API网关提供了迁移上云工具,您可以按照迁移工具的引导一步一步的完成路由配置的迁移及最终的流量切换。

迁移步骤.png

步骤一:路由规则迁移

  1. 登录云原生API网关控制台

  2. 在左侧导航栏,选择迁移上云

  3. 迁移上云页面,单击创建任务

  4. 创建迁移配置面板,进行相关配置。

    云原生API网关将自动监听所选容器集群内且关联到源IngressClass的所有Ingress资源的变化,并生效Ingress资源中域名和路由的相关配置。

    重要

    如果目标云原生API网关集群中已关联该容器集群,且已配置的IngressClass与此处的配置不同,则不允许迁移。请确保此处配置的IngressClass与已关联容器集群配置的IngressClass一致。

    image

    配置项

    说明

    所属环境

    指定迁移到云原生API网关的某个环境。

    来源集群

    选择要迁移的Nginx Ingress对应的容器集群,请确保云原生API网关与容器集群处于同一VPC。

    API名称

    Nginx Ingress路由将导入的云原生API网关的HTTP API名称。

    命名空间

    配置待迁移的Ingress资源的命名空间。

    IngressClass

    配置待迁移的Ingress资源关联的IngressClass资源。

    说明
    • 仅支持配置单个IngressClass。

    • 配置为空,即忽略IngressClass,表示监听集群中所有的Ingress资源。

  5. 单击下一步

    此时云原生API网关将自动监听所选容器集群内,关联到源IngressClass的所有Ingress资源的变化,并生效Ingress资源中域名、路由的相关配置到创建的API中。

    1. 假设在原有容器集群内有一个名称为nginx-routeIngress。

      image

    2. 在云原生API网关控制台可以看到目标集群中的Ingress已自动同步到目标云原生API网关中,并生成与之对应的域名、路由的相关配置。

      image

步骤二:路由校验

校验监听的Ingress的兼容性:

  • 如果无不兼容的Ingress Annotation,则继续下一步。

    image

  • 如果存在不兼容的Ingress Annotation,您可以提交工单咨询解决方案。

    重要
    • 注解nginx.ingress.kubernetes.io/service-weight的值为""可以忽略,该注解为旧版容器服务控制台默认添加,本身没有任何意义。

    • 迁移过程中,请勿删除线上正在使用的不兼容注解。因为这些不兼容的注解仍然被Nginx Ingress Controller解析并作用于您的业务流量。

    image

步骤三:切流选择

切流前测试

正式切流前,建议先进行本地测试:修改本地hosts文件,为业务域名添加云原生API网关SLB解析,通过curl或者postman等工具验证所有流量是否符合预期。

选择切流方式

复用原集群SLB

原理:将云原生API网关节点实例添加到原SLB的后端服务器组中,在迁移过程中根据设置的权重分配业务流量到云原生API网关。当迁移完成之后,访问该SLB的流量将全部转发至云原生API网关。

image

相关配置项说明如下:

配置项

说明

容器集群命名空间

选择Nginx Ingress SLB关联的K8s Service所在的命名空间。

容器集群SLB服务

选择Nginx Ingress SLB关联的K8s Service的名称。

SLB ID

单击查询到的SLB,确认该SLB是目标待迁移的SLB。

端口及后端服务器

选择原集群SLB实例的监听端口和网关协议(HTTP/HTTPS),会自动展示目标虚拟服务器组。

说明

请注意端口以及对应协议的选择,否则流量可能有损。

DNS解析至云原生API网关SLB

请您前往DNS供应商的域名解析服务,为迁移路由涉及的所有域名添加云原生API网关SLB地址的映射。建议使用DNS的权重解析方式逐步切流。

步骤四:流量切换

复用原集群SLB

image

Step1:点击变更SLB

点击变更SLB后,系统自动将SLB脱离容器托管并修改监听调度算法为加权轮询。

重要

该步骤会将SLB脱离容器托管,脱离之后无法感知Nginx Ingress ControllerPod IP变化,请尽快按照下一步的要求修改注解,重新将K8s Service关联至SLB。

Step2:覆盖修改Service注解

请确保完成Step1之后,在容器服务管理控制台中手工将复用原集群SLB选择的K8s Service的当前所有注解删除,复制流量切换页面自动生成的注解并添加到目标K8s Service注解中。该步骤主要是将原K8s Service改为复用SLB,修改完成后,单击前置检查,检查通过后,会进入下一步。

image

修改yaml.png

编辑yaml.png

Step3:基于权重开始切流

设置转发云原生API网关实例的流量权重,根据业务实际情况设置1~100,建议初次设置为1~10之间。

image

  • 该值为云原生API网关各节点的权重值总和,SLB会根据虚拟服务器组中云原生API网关和Nginx Ingress各节点的权重比值分配流量。其中Nginx Ingress节点的权重总和默认为100,所以当云原生API网关权重也设为100,则承接1/2 流量。依此类推,当云原生API网关权重设为50,则承接1/3流量。

  • 迁移过程中,可以通过云原生API网关提供的监控大盘观察网关各项指标,时刻关注网关健康状态以及业务指标是否符合预期。

    • 如果符合预期,可以逐步调大权重,修改权重的时间间隔要大于3分钟,因为后台是异步生效权重配置。

    • 如果不符合预期,权重设置为0即可,本次迁移终止。

  • 您可以在容器服务控制台中将复用原集群SLB选择的K8s Service的注解service.beta.kubernetes.io/alibaba-cloud-loadbalancer-weight的值调低,间接调大云原生API网关的权重。特别的,当该注解的值为0时,流量则全部导入云原生API网关。

  • SLB作为四层负载均衡,流量控制粒度为连接级别,该权重值无法精确控制请求级别的分发比例。

  • 切流后如果出现成功率下跌,可将该权重设为0进行流量快速回滚

说明

如果您希望长期处于迁移状态中,希望随时可以调整Nginx Ingress和云原生API网关 Ingress的流量权重,建议您长期处于当前步骤中。当您验证并确认流量符合预期,之后不再需要回滚所有流量到Nginx Ingress,可以单击完成流量验证继续下一步。

重要

单击完成流量验证后,将无法修改权重。

Step4:全部流量切换至云原生API网关

在容器服务控制台中将步骤三:切流选择选择的K8s Service服务的注解service.beta.kubernetes.io/alibaba-cloud-loadbalancer-weight的值设置为0,或者直接删除该Service资源。Nginx Ingress Controller的节点将会自动从该SLB摘除,则SLB的全部流量切换至云原生API网关。单击完成迁移,此次迁移任务结束。

image

迁移走了.png

DNS解析至云原生API网关SLB

image

请前往DNS供应商的域名解析服务,为迁移路由涉及的所有域名添加云原生API网关SLB地址的映射。建议使用DNS的权重解析方式逐步切流。

快速回滚

如果在流量迁移过程中发现不符合预期,您可以根据以下方式快速回滚,使流量恢复至Nginx Ingress Controller。

  • 复用原集群SLB:权重设置为0即可,本次迁移终止。

  • DNS解析至云原生API网关SLB:在DNS提供商上对所有的业务域名删掉云原生API网关SLB地址即可。

步骤五:完成迁移

复用原集群SLB

对于SLB切流方式,如果您还有其他SLB未切流完毕,请确保这些SLB完成切流。如果您已经完成了所有SLB的切流,后续您可以按需删除K8s Service以及Nginx Ingress Controller。

DNS解析至云原生API网关SLB

对于DNS切流方式,如果您所有业务域名的IP地址已经全部解析为云原生API网关的SLB地址列表,后续您可以按需删除K8s Service以及Nginx Ingress Controller。