Skip to content

Function App Concurrency and Dynamic Scaling does not seem to work #10586

@mystiqu

Description

@mystiqu

I have a consumption based function app (.Net 6, running in 64-bit mode) that keeps getting the warning "Your app is not configured for dynamic scaling. Scaling could be limited. Click to learn more."

Image

However, the thing is that dynamic scaling is enabled by having the following in the host.json file:

"concurrency": {
        "dynamicConcurrencyEnabled": true,
        "snapshotPersistenceEnabled": true
}

Something with scaling also seems off, not sure if it's related though.
It's a simple servicebus trigger, and if I add 10k message on the queue, the maximum throughput I get is 10 messages / second.
I should say that each messages take approx. 1.5s to process, but it's mostly idle/latency time due to other reasons.

The CPU is almost idle (avg cpu utilization is 7%) and most of the processing is done in the database (which peaks at 7%)
Checking the logs I can see that it's the same host instance that processes everything, so it seems it's never scaling out.

The persisted concurrency settings states that e.g. ProcessTrackingEventMessagesSBTrigger could run 503 executions in parallell - but that never happens.

{
    "Timestamp": "2024-10-30T19:40:37.6565727Z",
    "NumberOfCores": 2,
    "FunctionSnapshots": {
        "Host.Functions.ProcessTrackingEventMessagesSBTrigger": {
            "Concurrency": 503
        },
        "Host.Functions.ProcessCanonicalEvents": {
            "Concurrency": 54
        },
        "Host.Functions.ProcessPersistMessagesSBTrigger": {
            "Concurrency": 134
        },
        "Host.Functions.ProcessLogMessagesSBTrigger": {
            "Concurrency": 202
        }
    }
}

I've run out of ideas of what might be wrong at the moment.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions