public BackendLoadBalancingOptions(LoadBalancingMode mode,
                                               Func <IEnumerable <EndpointInfo>, BackendLoadBalancingOptions, EndpointInfo> callback = null,
                                               IDictionary <EndpointInfo, int> deficitRoundRobinQuanta             = null,
                                               Func <EndpointInfo> failOverPreferredEndpoint                       = null,
                                               Predicate <EndpointInfo> failOverIsAvailablePredicate               = null,
                                               Func <ILoadBalancingStrategy> failOverFallBackLoadBalancingStrategy = null,
                                               Func <IEnumerable <EndpointInfo>, IEnumerable <EndpointInfo> > trafficAllocationSelector = null,
                                               decimal?trafficAllocationVariation = null,
                                               Func <ILoadBalancingStrategy> trafficAllocationBackingLoadBalancingStrategy = null
                                               )
            {
                Mode = mode;

                // Increment returns the new value and we want the first return value to be 0.
                RoundRobinState = new AtomicCounter()
                {
                    Value = -1
                };

                Callback = callback;

                DeficitRoundRobinQuanta = deficitRoundRobinQuanta;

                FailOverPreferredEndpoint             = failOverPreferredEndpoint;
                FailOverIsAvailablePredicate          = failOverIsAvailablePredicate;
                FailOverFallBackLoadBalancingStrategy = failOverFallBackLoadBalancingStrategy;

                TrafficAllocationSelector  = trafficAllocationSelector;
                TrafficAllocationVariation = trafficAllocationVariation;
                TrafficAllocationBackingLoadBalancingStrategy = trafficAllocationBackingLoadBalancingStrategy;
            }
Exemple #2
0
 public ClusterLoadBalancingOptions(LoadBalancingMode mode)
 {
     Mode = mode;
     // Increment returns the new value and we want the first return value to be 0.
     RoundRobinState = new AtomicCounter()
     {
         Value = -1
     };
 }
Exemple #3
0
 private ILoadBalancingStrategy GetLoadBalancingStrategy(LoadBalancingMode loadBalancingMode, BackendConfig.BackendLoadBalancingOptions loadBalancingOptions)
 {
     return(loadBalancingMode switch
     {
         LoadBalancingMode.PowerOfTwoChoices => new PowerOfTwoChoicesLoadBalancingStrategy(_randomFactory),
         LoadBalancingMode.LeastRequests => LeastRequestsLoadBalancingStrategy.Instance,
         LoadBalancingMode.Random => new RandomLoadBalancingStrategy(_randomFactory),
         LoadBalancingMode.RoundRobin => RoundRobinLoadBalancingStrategy.Instance,
         LoadBalancingMode.First => FirstLoadBalancingStrategy.Instance,
         LoadBalancingMode.Callback => new CallbackLoadBalancingStrategy(loadBalancingOptions.Callback),
         LoadBalancingMode.DeficitRoundRobin => new DeficitRoundRobinLoadBalancingStrategy(loadBalancingOptions.DeficitRoundRobinQuanta),
         LoadBalancingMode.FailOver => new FailOverLoadBalancingStrategy(loadBalancingOptions.FailOverPreferredEndpoint(),
                                                                         loadBalancingOptions.FailOverIsAvailablePredicate, loadBalancingOptions.FailOverFallBackLoadBalancingStrategy),
         LoadBalancingMode.TrafficAllocation => new TrafficAllocationLoadBalancingStrategy(loadBalancingOptions.TrafficAllocationSelector,
                                                                                           loadBalancingOptions.TrafficAllocationVariation, loadBalancingOptions.TrafficAllocationBackingLoadBalancingStrategy()),
         _ => throw new NotSupportedException($"Load balancing mode '{loadBalancingMode}' is not supported.")
     });
Exemple #4
0
 public BackendLoadBalancingOptions(LoadBalancingMode mode)
 {
     Mode = mode;
 }
Exemple #5
0
        internal static AppServiceEnvironmentData DeserializeAppServiceEnvironmentData(JsonElement element)
        {
            Optional <string>            kind                             = default;
            IDictionary <string, string> tags                             = default;
            AzureLocation                       location                  = default;
            ResourceIdentifier                  id                        = default;
            string                              name                      = default;
            ResourceType                        type                      = default;
            SystemData                          systemData                = default;
            Optional <ProvisioningState>        provisioningState         = default;
            Optional <HostingEnvironmentStatus> status                    = default;
            Optional <VirtualNetworkProfile>    virtualNetwork            = default;
            Optional <LoadBalancingMode>        internalLoadBalancingMode = default;
            Optional <string>                   multiSize                 = default;
            Optional <int>                      multiRoleCount            = default;
            Optional <int>                      ipsslAddressCount         = default;
            Optional <string>                   dnsSuffix                 = default;
            Optional <int>                      maximumNumberOfMachines   = default;
            Optional <int>                      frontEndScaleFactor       = default;
            Optional <bool>                     suspended                 = default;
            Optional <IList <NameValuePair> >   clusterSettings           = default;
            Optional <IList <string> >          userWhitelistedIpRanges   = default;
            Optional <bool>                     hasLinuxWorkers           = default;
            Optional <int>                      dedicatedHostCount        = default;
            Optional <bool>                     zoneRedundant             = default;

            foreach (var property in element.EnumerateObject())
            {
                if (property.NameEquals("kind"))
                {
                    kind = property.Value.GetString();
                    continue;
                }
                if (property.NameEquals("tags"))
                {
                    Dictionary <string, string> dictionary = new Dictionary <string, string>();
                    foreach (var property0 in property.Value.EnumerateObject())
                    {
                        dictionary.Add(property0.Name, property0.Value.GetString());
                    }
                    tags = dictionary;
                    continue;
                }
                if (property.NameEquals("location"))
                {
                    location = property.Value.GetString();
                    continue;
                }
                if (property.NameEquals("id"))
                {
                    id = new ResourceIdentifier(property.Value.GetString());
                    continue;
                }
                if (property.NameEquals("name"))
                {
                    name = property.Value.GetString();
                    continue;
                }
                if (property.NameEquals("type"))
                {
                    type = property.Value.GetString();
                    continue;
                }
                if (property.NameEquals("systemData"))
                {
                    systemData = JsonSerializer.Deserialize <SystemData>(property.Value.ToString());
                    continue;
                }
                if (property.NameEquals("properties"))
                {
                    if (property.Value.ValueKind == JsonValueKind.Null)
                    {
                        property.ThrowNonNullablePropertyIsNull();
                        continue;
                    }
                    foreach (var property0 in property.Value.EnumerateObject())
                    {
                        if (property0.NameEquals("provisioningState"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            provisioningState = property0.Value.GetString().ToProvisioningState();
                            continue;
                        }
                        if (property0.NameEquals("status"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            status = property0.Value.GetString().ToHostingEnvironmentStatus();
                            continue;
                        }
                        if (property0.NameEquals("virtualNetwork"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            virtualNetwork = VirtualNetworkProfile.DeserializeVirtualNetworkProfile(property0.Value);
                            continue;
                        }
                        if (property0.NameEquals("internalLoadBalancingMode"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            internalLoadBalancingMode = new LoadBalancingMode(property0.Value.GetString());
                            continue;
                        }
                        if (property0.NameEquals("multiSize"))
                        {
                            multiSize = property0.Value.GetString();
                            continue;
                        }
                        if (property0.NameEquals("multiRoleCount"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            multiRoleCount = property0.Value.GetInt32();
                            continue;
                        }
                        if (property0.NameEquals("ipsslAddressCount"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            ipsslAddressCount = property0.Value.GetInt32();
                            continue;
                        }
                        if (property0.NameEquals("dnsSuffix"))
                        {
                            dnsSuffix = property0.Value.GetString();
                            continue;
                        }
                        if (property0.NameEquals("maximumNumberOfMachines"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            maximumNumberOfMachines = property0.Value.GetInt32();
                            continue;
                        }
                        if (property0.NameEquals("frontEndScaleFactor"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            frontEndScaleFactor = property0.Value.GetInt32();
                            continue;
                        }
                        if (property0.NameEquals("suspended"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            suspended = property0.Value.GetBoolean();
                            continue;
                        }
                        if (property0.NameEquals("clusterSettings"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            List <NameValuePair> array = new List <NameValuePair>();
                            foreach (var item in property0.Value.EnumerateArray())
                            {
                                array.Add(NameValuePair.DeserializeNameValuePair(item));
                            }
                            clusterSettings = array;
                            continue;
                        }
                        if (property0.NameEquals("userWhitelistedIpRanges"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            List <string> array = new List <string>();
                            foreach (var item in property0.Value.EnumerateArray())
                            {
                                array.Add(item.GetString());
                            }
                            userWhitelistedIpRanges = array;
                            continue;
                        }
                        if (property0.NameEquals("hasLinuxWorkers"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            hasLinuxWorkers = property0.Value.GetBoolean();
                            continue;
                        }
                        if (property0.NameEquals("dedicatedHostCount"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            dedicatedHostCount = property0.Value.GetInt32();
                            continue;
                        }
                        if (property0.NameEquals("zoneRedundant"))
                        {
                            if (property0.Value.ValueKind == JsonValueKind.Null)
                            {
                                property0.ThrowNonNullablePropertyIsNull();
                                continue;
                            }
                            zoneRedundant = property0.Value.GetBoolean();
                            continue;
                        }
                    }
                    continue;
                }
            }
            return(new AppServiceEnvironmentData(id, name, type, systemData, tags, location, kind.Value, Optional.ToNullable(provisioningState), Optional.ToNullable(status), virtualNetwork.Value, Optional.ToNullable(internalLoadBalancingMode), multiSize.Value, Optional.ToNullable(multiRoleCount), Optional.ToNullable(ipsslAddressCount), dnsSuffix.Value, Optional.ToNullable(maximumNumberOfMachines), Optional.ToNullable(frontEndScaleFactor), Optional.ToNullable(suspended), Optional.ToList(clusterSettings), Optional.ToList(userWhitelistedIpRanges), Optional.ToNullable(hasLinuxWorkers), Optional.ToNullable(dedicatedHostCount), Optional.ToNullable(zoneRedundant)));
        }