cancel
Showing results forย 
Search instead forย 
Did you mean:ย 
Machine Learning
Dive into the world of machine learning on the Databricks platform. Explore discussions on algorithms, model training, deployment, and more. Connect with ML enthusiasts and experts.
cancel
Showing results forย 
Search instead forย 
Did you mean:ย 

Facing issues with passing memory checkpointer in lanngraph agents

kishan_
New Contributor II

Hi,

I am trying to create a simple langgraph agent in Databricks, the agent also uses lanngraph memory checkpoint which enables to store the state of the graph. This is working fine when I am trying it in Databricks notebook, but when I tried to log this as Mlfow model, I couldn't find any documentation on where to pass the memory checkpoint

I want to know if there is way we can pass memory checkpoint when logging langgraph agent in Mlflow

1 ACCEPTED SOLUTION

Accepted Solutions

morenoj11
New Contributor III

I saw that you can compile the model without checkpointer, register it in MLflow, and then, after loading, assign it after compilation.

```

import mlflow

 

mlflow.models.set_model(build_graph())
with mlflow.start_run() as run_id:
model_info = mlflow.langchain.log_model(
lc_model="build_graph.py", # Path to our model Python file
artifact_path="langgraph",
)
model_uri = model_info.model_uri
[...]
 
loaded_model = mlflow.langchain.load_model(model_uri)
loaded_model.checkpointer = checkpointer
 
loaded_model.invoke(input_state, config)  ## config has the thread_id

```

It's not elegant or future-proof, but it might do the trick while we wait for a better solution.

View solution in original post

3 REPLIES 3

morenoj11
New Contributor III

Facing the same issue here.

morenoj11
New Contributor III

I saw that you can compile the model without checkpointer, register it in MLflow, and then, after loading, assign it after compilation.

```

import mlflow

 

mlflow.models.set_model(build_graph())
with mlflow.start_run() as run_id:
model_info = mlflow.langchain.log_model(
lc_model="build_graph.py", # Path to our model Python file
artifact_path="langgraph",
)
model_uri = model_info.model_uri
[...]
 
loaded_model = mlflow.langchain.load_model(model_uri)
loaded_model.checkpointer = checkpointer
 
loaded_model.invoke(input_state, config)  ## config has the thread_id

```

It's not elegant or future-proof, but it might do the trick while we wait for a better solution.

kishan_
New Contributor II

@morenoj11 The solution which you have mentioned, Have you tried to deploy the same in Databricks model serving ?

Connect with Databricks Users in Your Area

Join a Regional User Group to connect with local Databricks users. Events will be happening in your city, and you wonโ€™t want to miss the chance to attend and share knowledge.

If there isnโ€™t a group near you, start one and help create a community that brings people together.

Request a New Group