Code
cookbook/knowledge/vector_db/clickhouse_db/clickhouse.py
Copy
Ask AI
from agno.agent import Agent
from agno.knowledge.knowledge import Knowledge
from agno.vectordb.clickhouse import Clickhouse
vector_db = Clickhouse(
table_name="recipe_documents",
host="localhost",
port=8123,
username="ai",
password="ai",
)
knowledge = Knowledge(
name="My Clickhouse Knowledge Base",
description="This is a knowledge base that uses a Clickhouse DB",
vector_db=vector_db,
)
knowledge.add_content(
name="Recipes",
url="https://agno-public.s3.amazonaws.com/recipes/ThaiRecipes.pdf",
metadata={"doc_type": "recipe_book"},
)
agent = Agent(
knowledge=knowledge,
search_knowledge=True,
read_chat_history=True,
)
agent.print_response("How do I make pad thai?", markdown=True)
vector_db.delete_by_name("Recipes")
# or
vector_db.delete_by_metadata({"doc_type": "recipe_book"})
Usage
1
Create a virtual environment
Open the
Terminal and create a python virtual environment.Copy
Ask AI
python3 -m venv .venv
source .venv/bin/activate
2
Install libraries
Copy
Ask AI
pip install -U clickhouse-connect pypdf openai agno
3
Run ClickHouse
Copy
Ask AI
docker run -d \
-e CLICKHOUSE_DB=ai \
-e CLICKHOUSE_USER=ai \
-e CLICKHOUSE_PASSWORD=ai \
-e CLICKHOUSE_DEFAULT_ACCESS_MANAGEMENT=1 \
-v clickhouse_data:/var/lib/clickhouse/ \
-v clickhouse_log:/var/log/clickhouse-server/ \
-p 8123:8123 \
-p 9000:9000 \
--ulimit nofile=262144:262144 \
--name clickhouse-server \
clickhouse/clickhouse-server
4
Set environment variables
Copy
Ask AI
export CLICKHOUSE_HOST="localhost"
export CLICKHOUSE_PORT="8123"
export CLICKHOUSE_USER="ai"
export CLICKHOUSE_PASSWORD="ai"
export CLICKHOUSE_DB="ai"
export OPENAI_API_KEY=xxx
5
Run Agent
Copy
Ask AI
python cookbook/knowledge/vector_db/clickhouse_db/clickhouse.py