Class V1.TopologySpreadConstraint.Builder

java.lang.Object
com.google.protobuf.AbstractMessageLite.Builder
com.google.protobuf.AbstractMessage.Builder<BuilderType>
com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
io.kubernetes.client.proto.V1.TopologySpreadConstraint.Builder
All Implemented Interfaces:
com.google.protobuf.Message.Builder, com.google.protobuf.MessageLite.Builder, com.google.protobuf.MessageLiteOrBuilder, com.google.protobuf.MessageOrBuilder, V1.TopologySpreadConstraintOrBuilder, Cloneable
Enclosing class:
V1.TopologySpreadConstraint

public static final class V1.TopologySpreadConstraint.Builder extends com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder> implements V1.TopologySpreadConstraintOrBuilder
 TopologySpreadConstraint specifies how to spread matching pods among the given topology.
 
Protobuf type k8s.io.api.core.v1.TopologySpreadConstraint
  • Method Details

    • getDescriptor

      public static final com.google.protobuf.Descriptors.Descriptor getDescriptor()
    • internalGetFieldAccessorTable

      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable()
      Specified by:
      internalGetFieldAccessorTable in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • clear

      Specified by:
      clear in interface com.google.protobuf.Message.Builder
      Specified by:
      clear in interface com.google.protobuf.MessageLite.Builder
      Overrides:
      clear in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • getDescriptorForType

      public com.google.protobuf.Descriptors.Descriptor getDescriptorForType()
      Specified by:
      getDescriptorForType in interface com.google.protobuf.Message.Builder
      Specified by:
      getDescriptorForType in interface com.google.protobuf.MessageOrBuilder
      Overrides:
      getDescriptorForType in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • getDefaultInstanceForType

      public V1.TopologySpreadConstraint getDefaultInstanceForType()
      Specified by:
      getDefaultInstanceForType in interface com.google.protobuf.MessageLiteOrBuilder
      Specified by:
      getDefaultInstanceForType in interface com.google.protobuf.MessageOrBuilder
    • build

      Specified by:
      build in interface com.google.protobuf.Message.Builder
      Specified by:
      build in interface com.google.protobuf.MessageLite.Builder
    • buildPartial

      public V1.TopologySpreadConstraint buildPartial()
      Specified by:
      buildPartial in interface com.google.protobuf.Message.Builder
      Specified by:
      buildPartial in interface com.google.protobuf.MessageLite.Builder
    • clone

      Specified by:
      clone in interface com.google.protobuf.Message.Builder
      Specified by:
      clone in interface com.google.protobuf.MessageLite.Builder
      Overrides:
      clone in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • setField

      public V1.TopologySpreadConstraint.Builder setField(com.google.protobuf.Descriptors.FieldDescriptor field, Object value)
      Specified by:
      setField in interface com.google.protobuf.Message.Builder
      Overrides:
      setField in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • clearField

      public V1.TopologySpreadConstraint.Builder clearField(com.google.protobuf.Descriptors.FieldDescriptor field)
      Specified by:
      clearField in interface com.google.protobuf.Message.Builder
      Overrides:
      clearField in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • clearOneof

      public V1.TopologySpreadConstraint.Builder clearOneof(com.google.protobuf.Descriptors.OneofDescriptor oneof)
      Specified by:
      clearOneof in interface com.google.protobuf.Message.Builder
      Overrides:
      clearOneof in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • setRepeatedField

      public V1.TopologySpreadConstraint.Builder setRepeatedField(com.google.protobuf.Descriptors.FieldDescriptor field, int index, Object value)
      Specified by:
      setRepeatedField in interface com.google.protobuf.Message.Builder
      Overrides:
      setRepeatedField in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • addRepeatedField

      public V1.TopologySpreadConstraint.Builder addRepeatedField(com.google.protobuf.Descriptors.FieldDescriptor field, Object value)
      Specified by:
      addRepeatedField in interface com.google.protobuf.Message.Builder
      Overrides:
      addRepeatedField in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • mergeFrom

      public V1.TopologySpreadConstraint.Builder mergeFrom(com.google.protobuf.Message other)
      Specified by:
      mergeFrom in interface com.google.protobuf.Message.Builder
      Overrides:
      mergeFrom in class com.google.protobuf.AbstractMessage.Builder<V1.TopologySpreadConstraint.Builder>
    • mergeFrom

    • isInitialized

      public final boolean isInitialized()
      Specified by:
      isInitialized in interface com.google.protobuf.MessageLiteOrBuilder
      Overrides:
      isInitialized in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • mergeFrom

      public V1.TopologySpreadConstraint.Builder mergeFrom(com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws IOException
      Specified by:
      mergeFrom in interface com.google.protobuf.Message.Builder
      Specified by:
      mergeFrom in interface com.google.protobuf.MessageLite.Builder
      Overrides:
      mergeFrom in class com.google.protobuf.AbstractMessage.Builder<V1.TopologySpreadConstraint.Builder>
      Throws:
      IOException
    • hasMaxSkew

      public boolean hasMaxSkew()
       MaxSkew describes the degree to which pods may be unevenly distributed.
       When `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference
       between the number of matching pods in the target topology and the global minimum.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 1/1/0:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       |   P   |   P   |       |
       +-------+-------+-------+
       - if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1;
       scheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2)
       violate MaxSkew(1).
       - if MaxSkew is 2, incoming pod can be scheduled onto any zone.
       When `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence
       to topologies that satisfy it.
       It's a required field. Default value is 1 and 0 is not allowed.
       
      optional int32 maxSkew = 1;
      Specified by:
      hasMaxSkew in interface V1.TopologySpreadConstraintOrBuilder
    • getMaxSkew

      public int getMaxSkew()
       MaxSkew describes the degree to which pods may be unevenly distributed.
       When `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference
       between the number of matching pods in the target topology and the global minimum.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 1/1/0:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       |   P   |   P   |       |
       +-------+-------+-------+
       - if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1;
       scheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2)
       violate MaxSkew(1).
       - if MaxSkew is 2, incoming pod can be scheduled onto any zone.
       When `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence
       to topologies that satisfy it.
       It's a required field. Default value is 1 and 0 is not allowed.
       
      optional int32 maxSkew = 1;
      Specified by:
      getMaxSkew in interface V1.TopologySpreadConstraintOrBuilder
    • setMaxSkew

      public V1.TopologySpreadConstraint.Builder setMaxSkew(int value)
       MaxSkew describes the degree to which pods may be unevenly distributed.
       When `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference
       between the number of matching pods in the target topology and the global minimum.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 1/1/0:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       |   P   |   P   |       |
       +-------+-------+-------+
       - if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1;
       scheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2)
       violate MaxSkew(1).
       - if MaxSkew is 2, incoming pod can be scheduled onto any zone.
       When `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence
       to topologies that satisfy it.
       It's a required field. Default value is 1 and 0 is not allowed.
       
      optional int32 maxSkew = 1;
    • clearMaxSkew

      public V1.TopologySpreadConstraint.Builder clearMaxSkew()
       MaxSkew describes the degree to which pods may be unevenly distributed.
       When `whenUnsatisfiable=DoNotSchedule`, it is the maximum permitted difference
       between the number of matching pods in the target topology and the global minimum.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 1/1/0:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       |   P   |   P   |       |
       +-------+-------+-------+
       - if MaxSkew is 1, incoming pod can only be scheduled to zone3 to become 1/1/1;
       scheduling it onto zone1(zone2) would make the ActualSkew(2-0) on zone1(zone2)
       violate MaxSkew(1).
       - if MaxSkew is 2, incoming pod can be scheduled onto any zone.
       When `whenUnsatisfiable=ScheduleAnyway`, it is used to give higher precedence
       to topologies that satisfy it.
       It's a required field. Default value is 1 and 0 is not allowed.
       
      optional int32 maxSkew = 1;
    • hasTopologyKey

      public boolean hasTopologyKey()
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
      Specified by:
      hasTopologyKey in interface V1.TopologySpreadConstraintOrBuilder
    • getTopologyKey

      public String getTopologyKey()
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
      Specified by:
      getTopologyKey in interface V1.TopologySpreadConstraintOrBuilder
    • getTopologyKeyBytes

      public com.google.protobuf.ByteString getTopologyKeyBytes()
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
      Specified by:
      getTopologyKeyBytes in interface V1.TopologySpreadConstraintOrBuilder
    • setTopologyKey

      public V1.TopologySpreadConstraint.Builder setTopologyKey(String value)
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
    • clearTopologyKey

      public V1.TopologySpreadConstraint.Builder clearTopologyKey()
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
    • setTopologyKeyBytes

      public V1.TopologySpreadConstraint.Builder setTopologyKeyBytes(com.google.protobuf.ByteString value)
       TopologyKey is the key of node labels. Nodes that have a label with this key
       and identical values are considered to be in the same topology.
       We consider each <key, value> as a "bucket", and try to put balanced number
       of pods into each bucket.
       It's a required field.
       
      optional string topologyKey = 2;
    • hasWhenUnsatisfiable

      public boolean hasWhenUnsatisfiable()
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
      Specified by:
      hasWhenUnsatisfiable in interface V1.TopologySpreadConstraintOrBuilder
    • getWhenUnsatisfiable

      public String getWhenUnsatisfiable()
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
      Specified by:
      getWhenUnsatisfiable in interface V1.TopologySpreadConstraintOrBuilder
    • getWhenUnsatisfiableBytes

      public com.google.protobuf.ByteString getWhenUnsatisfiableBytes()
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
      Specified by:
      getWhenUnsatisfiableBytes in interface V1.TopologySpreadConstraintOrBuilder
    • setWhenUnsatisfiable

      public V1.TopologySpreadConstraint.Builder setWhenUnsatisfiable(String value)
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
    • clearWhenUnsatisfiable

      public V1.TopologySpreadConstraint.Builder clearWhenUnsatisfiable()
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
    • setWhenUnsatisfiableBytes

      public V1.TopologySpreadConstraint.Builder setWhenUnsatisfiableBytes(com.google.protobuf.ByteString value)
       WhenUnsatisfiable indicates how to deal with a pod if it doesn't satisfy
       the spread constraint.
       - DoNotSchedule (default) tells the scheduler not to schedule it.
       - ScheduleAnyway tells the scheduler to schedule the pod in any location,
         but giving higher precedence to topologies that would help reduce the
         skew.
       A constraint is considered "Unsatisfiable" for an incoming pod
       if and only if every possible node assignment for that pod would violate
       "MaxSkew" on some topology.
       For example, in a 3-zone cluster, MaxSkew is set to 1, and pods with the same
       labelSelector spread as 3/1/1:
       +-------+-------+-------+
       | zone1 | zone2 | zone3 |
       +-------+-------+-------+
       | P P P |   P   |   P   |
       +-------+-------+-------+
       If WhenUnsatisfiable is set to DoNotSchedule, incoming pod can only be scheduled
       to zone2(zone3) to become 3/2/1(3/1/2) as ActualSkew(2-1) on zone2(zone3) satisfies
       MaxSkew(1). In other words, the cluster can still be imbalanced, but scheduler
       won't make it *more* imbalanced.
       It's a required field.
       
      optional string whenUnsatisfiable = 3;
    • hasLabelSelector

      public boolean hasLabelSelector()
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
      Specified by:
      hasLabelSelector in interface V1.TopologySpreadConstraintOrBuilder
    • getLabelSelector

      public Meta.LabelSelector getLabelSelector()
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
      Specified by:
      getLabelSelector in interface V1.TopologySpreadConstraintOrBuilder
    • setLabelSelector

       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
    • setLabelSelector

      public V1.TopologySpreadConstraint.Builder setLabelSelector(Meta.LabelSelector.Builder builderForValue)
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
    • mergeLabelSelector

      public V1.TopologySpreadConstraint.Builder mergeLabelSelector(Meta.LabelSelector value)
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
    • clearLabelSelector

      public V1.TopologySpreadConstraint.Builder clearLabelSelector()
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
    • getLabelSelectorBuilder

      public Meta.LabelSelector.Builder getLabelSelectorBuilder()
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
    • getLabelSelectorOrBuilder

      public Meta.LabelSelectorOrBuilder getLabelSelectorOrBuilder()
       LabelSelector is used to find matching pods.
       Pods that match this label selector are counted to determine the number of pods
       in their corresponding topology domain.
       +optional
       
      optional .k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector labelSelector = 4;
      Specified by:
      getLabelSelectorOrBuilder in interface V1.TopologySpreadConstraintOrBuilder
    • setUnknownFields

      public final V1.TopologySpreadConstraint.Builder setUnknownFields(com.google.protobuf.UnknownFieldSet unknownFields)
      Specified by:
      setUnknownFields in interface com.google.protobuf.Message.Builder
      Overrides:
      setUnknownFields in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>
    • mergeUnknownFields

      public final V1.TopologySpreadConstraint.Builder mergeUnknownFields(com.google.protobuf.UnknownFieldSet unknownFields)
      Specified by:
      mergeUnknownFields in interface com.google.protobuf.Message.Builder
      Overrides:
      mergeUnknownFields in class com.google.protobuf.GeneratedMessageV3.Builder<V1.TopologySpreadConstraint.Builder>