在容器服务K8s集群中创建或部署应用时,您可以根据实际需求修改应用实例的调度规则,将Pod实例尽可能多可用区和多节点部署,来增强应用的可用性。

在创建应用时配调度规则

  1. 登录EDAS控制台
  2. 在左侧导航栏中单击应用列表,在顶部菜单栏选择地域并在页面上方选择微服务空间,然后在应用列表页面左上角单击创建应用
  3. 应用基本信息页签选择集群类型和应用运行环境,然后在页面最下方单击下一步
    参数 描述
    集群类型 选择Kubernetes集群
    应用运行环境 根据选择的托管应用类型选择应用运行环境。
    • Java
      • 自定义:适用于在K8s集群中使用自定义的镜像部署应用。
      • Java:支持通用的JAR包部署,适用于Dubbo和Spring Boot应用。在选择后可更改Java环境。
      • Tomcat:支持通用的WAR包部署,适用于Dubbo和Spring应用。在选择后可更改Java环境和容器版本。
      • EDAS-Container(HSF):适用于使用WAR或者FatJar部署HSF应用。在选择后可更改Java环境、Pandora版本和Ali-Tomcat版本。
    • PHP:适用于运行在Apache HTTP Server中的PHP应用程序。
    • 多语言Node、C++、Go…:适用于任何语言的使用自定义镜像来部署的微服务应用。
  4. 应用配置页签中设置应用的环境信息、基本信息、部署方式和资源参数,设置完成后单击下一步
  5. 应用高级设置页签展开调度规则,并根据您的业务需求设置调度模式和规则。
    • 选择内置配置

      可用区调度:

      • 默认调度:实例默认按照集群资源情况调度,所有实例有可能部署于单可用区,可用性一般。
      • 尽量多可用区部署:实例会利用反亲和性,尽可能分散部署到多可用区,可用性高。

      节点调度:

      • 默认调度:实例默认按照节点资源负载情况调度。
      • 尽量多节点部署:同一应用的实例,将尽量打散到不同节点上部署,以实现应用高可用部署。
    • 选择自定义配置

      如果内置的按节点与可用区的配置调度规则无法满足您对于复杂场景的需求时,您可以使用EDAS提供的自定义配置功能,根据实际业务场景来设计调度规则。

    表 1. 添加节点亲和性调度规则
    参数名 描述
    控制器

    您可以通过配置节点标签名操作符号节点标签值来指定节点的调度规则。

    权重 权重值允许设置0-100,默认权重值为1 。
    表 2. 添加应用亲和性调度规则
    参数名 描述
    K8s 命名空间

    应用关联的K8s命名空间。

    拓扑域 K8s 集群中为方便管理划分的一种“位置”关系,如节点、可用区、区域等。
    控制器

    您可以通过配置应用标签名操作符号应用标签值来指定调度约束条件。

    权重 权重值允许设置0-100,默认权重值为1。
    表 3. 添加应用反亲和性调度规则
    参数名 描述
    K8s 命名空间

    应用关联的K8s命名空间。

    拓扑域 K8s 集群中为方便管理划分的一种“位置”关系,如节点、可用区、区域等。
    控制器

    您可以通过配置应用标签名操作符号应用标签值来指定调度约束条件。

    权重 权重值允许设置0-100,默认权重值为1 。
    表 4. 添加调度容忍规则
    参数名 描述
    标签名

    调度容忍规则作用的对象。

    操作符号 操作符定义了其对调度规则的作用。
    标签值 标签对应的值。调度容忍是应用由标签名标签值操作符以及效果这四部分去匹配合适的污点。
    效果 匹配到节点对应污点后,应用运行的效果。
    容忍时间(秒) 匹配到节点对应污点后,应用在节点上可以继续运行的时间。若不指定该字段则表示应用可以一直运行在该节点。当操作符号取值为NoExecute时,您才可以配置容忍时间。
  6. 完成设置后单击创建应用
  7. 应用创建完成页签确认应用基本信息应用配置应用高级设置等信息,确认完毕后单击确定创建应用
    在应用应用总览页面顶部提示信息中单击查看详情,可在变更记录页面查看变更流程。应用部署需要几分钟,请您耐心等待。变更完成后在应用总览页面的基本信息区域查看实例的运行状态,如果显示为Pod运行中,说明应用部署成功。

在更新应用时配调度规则

您可在创建应用时配置调度规则,也可以在部署应用时配置或更新调度规则。

  1. 登录EDAS控制台
  2. 在左侧导航栏中单击应用列表,在顶部菜单栏选择地域并在页面上方选择微服务空间,在集群类型下拉列表中选择容器服务/Serverless K8s集群,然后在页面单击具体的应用名称。
  3. 应用总览基本信息页面的右上角选择部署 > 部署
  4. 选择部署模式页面选择具体的部署方式,然后在所选方式区域的右上角单击开始部署
  5. 设置应用的环境和部署包信息后展开调度规则,根据您的需求完成配置后单击确定
    • 选择内置配置

      可用区调度:

      • 默认调度:实例默认按照集群资源情况调度,所有实例有可能部署于单可用区,可用性一般。
      • 尽量多可用区部署:实例会利用反亲和性,尽可能分散部署到多可用区,可用性高。

      节点调度:

      • 默认调度:实例默认按照节点资源负载情况调度。
      • 尽量多节点部署:同一应用的实例,将尽量打散到不同节点上部署,以实现应用高可用部署。
    • 选择自定义配置

      如果内置的按节点与可用区的配置调度规则无法满足您对于复杂场景的需求时,您可以使用EDAS提供的自定义配置功能,根据实际业务场景来设计调度规则。

    表 5. 添加节点亲和性调度规则
    参数名 描述
    控制器

    您可以通过配置节点标签名操作符号节点标签值来指定节点的调度规则。

    权重 权重值允许设置0-100,默认权重值为1 。
    表 6. 添加应用亲和性调度规则
    参数名 描述
    K8s 命名空间

    应用关联的K8s命名空间。

    拓扑域 K8s 集群中为方便管理划分的一种“位置”关系,如节点、可用区、区域等。
    控制器

    您可以通过配置应用标签名操作符号应用标签值来指定调度约束条件。

    权重 权重值允许设置0-100,默认权重值为1。
    表 7. 添加应用反亲和性调度规则
    参数名 描述
    K8s 命名空间

    应用关联的K8s命名空间。

    拓扑域 K8s 集群中为方便管理划分的一种“位置”关系,如节点、可用区、区域等。
    控制器

    您可以通过配置应用标签名操作符号应用标签值来指定调度约束条件。

    权重 权重值允许设置0-100,默认权重值为1 。
    表 8. 添加调度容忍规则
    参数名 描述
    标签名

    调度容忍规则作用的对象。

    操作符号 操作符定义了其对调度规则的作用。
    标签值 标签对应的值。调度容忍是应用由标签名标签值操作符以及效果这四部分去匹配合适的污点。
    效果 匹配到节点对应污点后,应用运行的效果。
    容忍时间(秒) 匹配到节点对应污点后,应用在节点上可以继续运行的时间。若不指定该字段则表示应用可以一直运行在该节点。当操作符号取值为NoExecute时,您才可以配置容忍时间。
    注意 单击确定后,该应用将会被重启,请在业务较少的时间段进行。