Skip to content

INVALID_CONCURRENT_GRAPH_UPDATE

A LangGraph StateGraph received concurrent updates to its state from multiple nodes to a state property that doesn't support it.

One way this can occur is if you are using a fanout or other parallel execution in your graph and you have defined a graph like this:

class State(TypedDict):
    some_key: str

def node(state: State):
    return {"some_key": "some_string_value"}

def other_node(state: State):
    return {"some_key": "some_string_value"}


builder = StateGraph(State)
builder.add_node(node)
builder.add_node(other_node)
builder.add_edge(START, "node")
builder.add_edge(START, "other_node")
graph = builder.compile()

If a node in the above graph returns { "some_key": "some_string_value" }, this will overwrite the state value for "some_key" with "some_string_value". However, if multiple nodes in e.g. a fanout within a single step return values for "some_key", the graph will throw this error because there is uncertainty around how to update the internal state.

To get around this, you can define a reducer that combines multiple values:

import operator
from typing import Annotated

class State(TypedDict):
    # The operator.add reducer fn makes this append-only
    some_key: Annotated[list, operator.add]

This will allow you to define logic that handles the same key returned from multiple nodes executed in parallel.

Troubleshooting

The following may help resolve this error:

  • If your graph executes nodes in parallel, make sure you have defined relevant state keys with a reducer.

Comments