Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Log AI agents using Mosaic AI Agent Framework. Logging an agent is the basis of the development process. Logging captures a "point in time" of the agent's code and configuration so you can evaluate the quality of the configuration.
Requirements
Create an AI agent before logging it.
Databricks recommends installing the latest version of the databricks-sdk.
% pip install databricks-sdk
Code-based logging
Databricks recommends using MLflow's Models from Code functionality when logging agents.
In this approach, the agent's code is captured as a Python file, and the Python environment is captured as a list of packages. When the agent is deployed, the Python environment is restored, and the agent's code is run to load the agent into memory so it can be invoked when the endpoint is called.
You can couple this approach with the use of pre-deployment validation APIs like mlflow.models.predict() to ensure that the agent runs reliably when deployed for serving.
To see an example of code-based logging, see ResponsesAgent authoring example notebooks.
Infer Model Signature during logging
Note
Databricks recommends authoring an agent using the ResponsesAgent interface. If using ResponsesAgent, you can skip this section; MLflow automatically infers a valid signature for your agent.
If not using the ResponsesAgent interface, you must use one of the following methods to specify your agent's MLflow Model Signature at logging time:
- Manually define the signature
- Use MLflow's Model Signature inferencing capabilities to automatically generate the agent's signature based on an input example you provide. This approach is more convenient than manually defining the signature.
The MLflow model signature validates inputs and outputs to ensure the agent interacts correctly with downstream tools like AI Playground and the review app. It also guides other applications on how to use the agent effectively.
The LangChain and PyFunc examples below use Model Signature inferencing.
If you would rather explicitly define a Model Signature yourself at logging time, see MLflow docs - How to log models with signatures.
Code-based logging with LangChain
The following instructions and code sample show you how to log an agent with LangChain.
- Create a notebook or Python file with your code. For this example, the notebook or file is named - agent.py. The notebook or file must contain a LangChain agent, referred to here as- lc_agent.
- Include mlflow.models.set_model(lc_agent) in the notebook or file. 
- Create a new notebook to serve as the driver notebook (called - driver.pyin this example).
- In the driver notebook, use the following code to run - agent.pyand log the results to an MLflow model:- mlflow.langchain.log_model(lc_model="/path/to/agent.py", resources=list_of_databricks_resources)- The - resourcesparameter declares Databricks-managed resources needed to serve the agent, such as a vector search index or serving endpoint that serves a foundation model. For more information, see Implement automatic authentication passthrough.
- Deploy the model. See Deploy an agent for generative AI applications. 
- When the serving environment is loaded, - agent.pyis run.
- When a serving request comes in, - lc_agent.invoke(...)is called.
import mlflow
code_path = "/Workspace/Users/first.last/agent.py"
config_path = "/Workspace/Users/first.last/config.yml"
# Input example used by MLflow to infer Model Signature
input_example = {
  "messages": [
    {
      "role": "user",
      "content": "What is Retrieval-augmented Generation?",
    }
  ]
}
# example using langchain
with mlflow.start_run():
  logged_agent_info = mlflow.langchain.log_model(
    lc_model=code_path,
    model_config=config_path, # If you specify this parameter, this configuration is used by agent code. The development_config is overwritten.
    artifact_path="agent", # This string is used as the path inside the MLflow model where artifacts are stored
    input_example=input_example, # Must be a valid input to the agent
    example_no_conversion=True, # Required
  )
print(f"MLflow Run: {logged_agent_info.run_id}")
print(f"Model URI: {logged_agent_info.model_uri}")
# To verify that the model has been logged correctly, load the agent and call `invoke`:
model = mlflow.langchain.load_model(logged_agent_info.model_uri)
model.invoke(example)
Code-based logging with PyFunc
The following instructions and code sample show you how to log an agent with PyFunc.
- Create a notebook or Python file with your code. For this example, the notebook or file is named - agent.py. The notebook or file must contain a PyFunc class, named- PyFuncClass.
- Include - mlflow.models.set_model(PyFuncClass)in the notebook or file.
- Create a new notebook to serve as the driver notebook (called - driver.pyin this example).
- In the driver notebook, use the following code to run - agent.pyand use- log_model()to log the results to an MLflow model:- mlflow.pyfunc.log_model(python_model="/path/to/agent.py", resources=list_of_databricks_resources)- The - resourcesparameter declares Databricks-managed resources needed to serve the agent, such as a vector search index or serving endpoint that serves a foundation model. For more information, see Implement automatic authentication passthrough.
- Deploy the model. See Deploy an agent for generative AI applications. 
- When the serving environment is loaded, - agent.pyis run.
- When a serving request comes in, - PyFuncClass.predict(...)is called.
import mlflow
from mlflow.models.resources import (
    DatabricksServingEndpoint,
    DatabricksVectorSearchIndex,
)
code_path = "/Workspace/Users/first.last/agent.py"
config_path = "/Workspace/Users/first.last/config.yml"
# Input example used by MLflow to infer Model Signature
input_example = {
  "messages": [
    {
      "role": "user",
      "content": "What is Retrieval-augmented Generation?",
    }
  ]
}
with mlflow.start_run():
  logged_agent_info = mlflow.pyfunc.log_model(
    python_model=agent_notebook_path,
    artifact_path="agent",
    input_example=input_example,
    resources=resources_path,
    example_no_conversion=True,
    resources=[
      DatabricksServingEndpoint(endpoint_name="databricks-meta-llama-3-3-70b-instruct"),
      DatabricksVectorSearchIndex(index_name="prod.agents.databricks_docs_index"),
    ]
  )
print(f"MLflow Run: {logged_agent_info.run_id}")
print(f"Model URI: {logged_agent_info.model_uri}")
# To verify that the model has been logged correctly, load the agent and call `invoke`:
model = mlflow.pyfunc.load_model(logged_agent_info.model_uri)
model.invoke(example)
Authentication for Databricks resources
AI agents often need to authenticate to other resources to complete tasks. For example, a deployed agent might need to access a Vector Search index to query unstructured data, or access the Prompt Registry to load dynamic prompts.
Automatic authentication passthrough and on-behalf-of authentication require configuration during agent logging.
Register the agent to Unity Catalog
Before you deploy the agent, you must register the agent to Unity Catalog. Registering the agent packages it as a model in Unity Catalog. As a result, you can use Unity Catalog permissions for authorization for resources in the agent.
import mlflow
mlflow.set_registry_uri("databricks-uc")
catalog_name = "test_catalog"
schema_name = "schema"
model_name = "agent_name"
model_name = catalog_name + "." + schema_name + "." + model_name
uc_model_info = mlflow.register_model(model_uri=logged_agent_info.model_uri, name=model_name)