Skip to content

CrewAI integration

Astrocyte as shared crew memory and per-agent memory for CrewAI applications.

Module: astrocyte.integrations.crewai Pattern: Crew/agent memory — save, search, reset, per-agent banks Framework dependency: crewai (optional)

Terminal window
pip install astrocyte crewai
from astrocyte import Astrocyte
from astrocyte.integrations.crewai import AstrocyteCrewMemory
brain = Astrocyte.from_config("astrocyte.yaml")
# Shared crew memory + per-agent banks
memory = AstrocyteCrewMemory(
brain,
bank_id="team-shared",
agent_banks={"devops": "devops-bank", "researcher": "research-bank"},
)
# Save with agent attribution
await memory.save(
"Kubernetes deploys via Helm charts",
agent_id="devops",
tags=["infrastructure"],
)
# Search across the crew's shared bank
results = await memory.search("deployment strategy")
# Reset a specific agent's memory
await memory.reset(agent_id="devops")
CrewAI operationAstrocyte call
memory.save(content, agent_id=...)brain.retain() with agent metadata
memory.search(query, agent_id=...)brain.recall() scoped to agent or shared bank
memory.reset(agent_id=...)brain.forget(scope="all") on the agent’s bank

AstrocyteCrewMemory(brain, bank_id, *, agent_banks=None, auto_retain=False)

Section titled “AstrocyteCrewMemory(brain, bank_id, *, agent_banks=None, auto_retain=False)”
ParameterTypeDescription
brainAstrocyteConfigured Astrocyte instance
bank_idstrShared crew bank
agent_banksdict[str, str]Agent ID → bank ID mapping for per-agent memory
auto_retainboolAuto-retain after each task (default: False)
  • save(content, *, agent_id=None, tags=None, metadata=None)None
  • search(query, *, agent_id=None, max_results=5, tags=None)list[dict]
  • reset(*, agent_id=None)None