| # What does this PR do? - as title, cleaning up `import *`'s - upgrade tests to make them more robust to bad model outputs - remove import *'s in llama_stack/apis/* (skip __init__ modules) <img width="465" alt="image" src="https://github.com/user-attachments/assets/d8339c13-3b40-4ba5-9c53-0d2329726ee2" /> - run `sh run_openapi_generator.sh`, no types gets affected ## Test Plan ### Providers Tests **agents** ``` pytest -v -s llama_stack/providers/tests/agents/test_agents.py -m "together" --safety-shield meta-llama/Llama-Guard-3-8B --inference-model meta-llama/Llama-3.1-405B-Instruct-FP8 ``` **inference** ```bash # meta-reference torchrun $CONDA_PREFIX/bin/pytest -v -s -k "meta_reference" --inference-model="meta-llama/Llama-3.1-8B-Instruct" ./llama_stack/providers/tests/inference/test_text_inference.py torchrun $CONDA_PREFIX/bin/pytest -v -s -k "meta_reference" --inference-model="meta-llama/Llama-3.2-11B-Vision-Instruct" ./llama_stack/providers/tests/inference/test_vision_inference.py # together pytest -v -s -k "together" --inference-model="meta-llama/Llama-3.1-8B-Instruct" ./llama_stack/providers/tests/inference/test_text_inference.py pytest -v -s -k "together" --inference-model="meta-llama/Llama-3.2-11B-Vision-Instruct" ./llama_stack/providers/tests/inference/test_vision_inference.py pytest ./llama_stack/providers/tests/inference/test_prompt_adapter.py ``` **safety** ``` pytest -v -s llama_stack/providers/tests/safety/test_safety.py -m together --safety-shield meta-llama/Llama-Guard-3-8B ``` **memory** ``` pytest -v -s llama_stack/providers/tests/memory/test_memory.py -m "sentence_transformers" --env EMBEDDING_DIMENSION=384 ``` **scoring** ``` pytest -v -s -m llm_as_judge_scoring_together_inference llama_stack/providers/tests/scoring/test_scoring.py --judge-model meta-llama/Llama-3.2-3B-Instruct pytest -v -s -m basic_scoring_together_inference llama_stack/providers/tests/scoring/test_scoring.py pytest -v -s -m braintrust_scoring_together_inference llama_stack/providers/tests/scoring/test_scoring.py ``` **datasetio** ``` pytest -v -s -m localfs llama_stack/providers/tests/datasetio/test_datasetio.py pytest -v -s -m huggingface llama_stack/providers/tests/datasetio/test_datasetio.py ``` **eval** ``` pytest -v -s -m meta_reference_eval_together_inference llama_stack/providers/tests/eval/test_eval.py pytest -v -s -m meta_reference_eval_together_inference_huggingface_datasetio llama_stack/providers/tests/eval/test_eval.py ``` ### Client-SDK Tests ``` LLAMA_STACK_BASE_URL=http://localhost:5000 pytest -v ./tests/client-sdk ``` ### llama-stack-apps ``` PORT=5000 LOCALHOST=localhost python -m examples.agents.hello $LOCALHOST $PORT python -m examples.agents.inflation $LOCALHOST $PORT python -m examples.agents.podcast_transcript $LOCALHOST $PORT python -m examples.agents.rag_as_attachments $LOCALHOST $PORT python -m examples.agents.rag_with_memory_bank $LOCALHOST $PORT python -m examples.safety.llama_guard_demo_mm $LOCALHOST $PORT python -m examples.agents.e2e_loop_with_custom_tools $LOCALHOST $PORT # Vision model python -m examples.interior_design_assistant.app python -m examples.agent_store.app $LOCALHOST $PORT ``` ### CLI ``` which llama llama model prompt-format -m Llama3.2-11B-Vision-Instruct llama model list llama stack list-apis llama stack list-providers inference llama stack build --template ollama --image-type conda ``` ### Distributions Tests **ollama** ``` llama stack build --template ollama --image-type conda ollama run llama3.2:1b-instruct-fp16 llama stack run ./llama_stack/templates/ollama/run.yaml --env INFERENCE_MODEL=meta-llama/Llama-3.2-1B-Instruct ``` **fireworks** ``` llama stack build --template fireworks --image-type conda llama stack run ./llama_stack/templates/fireworks/run.yaml ``` **together** ``` llama stack build --template together --image-type conda llama stack run ./llama_stack/templates/together/run.yaml ``` **tgi** ``` llama stack run ./llama_stack/templates/tgi/run.yaml --env TGI_URL=http://0.0.0.0:5009 --env INFERENCE_MODEL=meta-llama/Llama-3.1-8B-Instruct ``` ## Sources Please link relevant resources if necessary. ## Before submitting - [ ] This PR fixes a typo or improves the docs (you can dismiss the other checks if that's the case). - [ ] Ran pre-commit to handle lint / formatting issues. - [ ] Read the [contributor guideline](https://github.com/meta-llama/llama-stack/blob/main/CONTRIBUTING.md), Pull Request section? - [ ] Updated relevant documentation. - [ ] Wrote necessary unit or integration tests. | ||
|---|---|---|
| .. | ||
| .env.template | ||
| 00_Inference101.ipynb | ||
| 01_Local_Cloud_Inference101.ipynb | ||
| 02_Prompt_Engineering101.ipynb | ||
| 03_Image_Chat101.ipynb | ||
| 04_Tool_Calling101.ipynb | ||
| 05_Memory101.ipynb | ||
| 06_Safety101.ipynb | ||
| 07_Agents101.ipynb | ||
| README.md | ||
| Tool_Calling101_Using_Together's_Llama_Stack_Server.ipynb | ||
Llama Stack: from Zero to Hero
Llama Stack defines and standardizes the set of core building blocks needed to bring generative AI applications to market. These building blocks are presented in the form of interoperable APIs with a broad set of Providers providing their implementations. These building blocks are assembled into Distributions which are easy for developers to get from zero to production.
This guide will walk you through an end-to-end workflow with Llama Stack with Ollama as the inference provider and ChromaDB as the memory provider. Please note the steps for configuring your provider and distribution will vary a little depending on the services you use. However, the user experience will remain universal - this is the power of Llama-Stack.
If you're looking for more specific topics, we have a Zero to Hero Guide that covers everything from Tool Calling to Agents in detail. Feel free to skip to the end to explore the advanced topics you're interested in.
If you'd prefer not to set up a local server, explore our notebook on tool calling with the Together API. This notebook will show you how to leverage together.ai's Llama Stack Server API, allowing you to get started with Llama Stack without the need for a locally built and running server.
Table of Contents
- Setup and run ollama
- Install Dependencies and Set Up Environment
- Build, Configure, and Run Llama Stack
- Test with llama-stack-client CLI
- Test with curl
- Test with Python
- Next Steps
Setup ollama
- 
Download Ollama App: - Go to https://ollama.com/download.
- Follow instructions based on the OS you are on. For example, if you are on a Mac, download and unzip Ollama-darwin.zip.
- Run the Ollamaapplication.
 
- 
Download the Ollama CLI: Ensure you have the ollamacommand line tool by downloading and installing it from the same website.
- 
Start ollama server: Open the terminal and run: ollama serve
- 
Run the model: Open the terminal and run: ollama run llama3.2:3b-instruct-fp16 --keepalive -1mNote: - The supported models for llama stack for now is listed in here
- keepalive -1mis used so that ollama continues to keep the model in memory indefinitely. Otherwise, ollama frees up memory and you would have to run- ollama runagain.
 
Install Dependencies and Set Up Environment
- 
Create a Conda Environment: Create a new Conda environment with Python 3.10: conda create -n ollama python=3.10Activate the environment: conda activate ollama
- 
Install ChromaDB: Install chromadbusingpip:pip install chromadb
- 
Run ChromaDB: Start the ChromaDB server: chroma run --host localhost --port 8000 --path ./my_chroma_data
- 
Install Llama Stack: Open a new terminal and install llama-stack:conda activate ollama pip install llama-stack==0.0.55
Build, Configure, and Run Llama Stack
- 
Build the Llama Stack: Build the Llama Stack using the ollamatemplate:llama stack build --template ollama --image-type condaExpected Output: ... Build Successful! Next steps: 1. Set the environment variables: LLAMASTACK_PORT, OLLAMA_URL, INFERENCE_MODEL, SAFETY_MODEL 2. `llama stack run /Users/<username>/.llama/distributions/llamastack-ollama/ollama-run.yaml
- 
Set the ENV variables by exporting them to the terminal: export OLLAMA_URL="http://localhost:11434" export LLAMA_STACK_PORT=5051 export INFERENCE_MODEL="meta-llama/Llama-3.2-3B-Instruct" export SAFETY_MODEL="meta-llama/Llama-Guard-3-1B"
- 
Run the Llama Stack: Run the stack with command shared by the API from earlier: llama stack run ollama \ --port $LLAMA_STACK_PORT \ --env INFERENCE_MODEL=$INFERENCE_MODEL \ --env SAFETY_MODEL=$SAFETY_MODEL \ --env OLLAMA_URL=$OLLAMA_URLNote: Everytime you run a new model with ollama run, you will need to restart the llama stack. Otherwise it won't see the new model.
The server will start and listen on http://localhost:5051.
Test with llama-stack-client CLI
After setting up the server, open a new terminal window and install the llama-stack-client package.
- Install the llama-stack-client package
conda activate ollama pip install llama-stack-client
- Configure the CLI to point to the llama-stack server.
 Expected Output:llama-stack-client configure --endpoint http://localhost:5051Done! You can now use the Llama Stack Client CLI with endpoint http://localhost:5051
- Test the CLI by running inference:
 Expected Output:llama-stack-client inference chat-completion --message "Write me a 2-sentence poem about the moon"ChatCompletionResponse( completion_message=CompletionMessage( content='Here is a 2-sentence poem about the moon:\n\nSilver crescent shining bright in the night,\nA beacon of wonder, full of gentle light.', role='assistant', stop_reason='end_of_turn', tool_calls=[] ), logprobs=None )
Test with curl
After setting up the server, open a new terminal window and verify it's working by sending a POST request using curl:
curl http://localhost:$LLAMA_STACK_PORT/inference/chat_completion \
-H "Content-Type: application/json" \
-d '{
    "model": "Llama3.2-3B-Instruct",
    "messages": [
        {"role": "system", "content": "You are a helpful assistant."},
        {"role": "user", "content": "Write me a 2-sentence poem about the moon"}
    ],
    "sampling_params": {"temperature": 0.7, "seed": 42, "max_tokens": 512}
}'
You can check the available models with the command llama-stack-client models list.
Expected Output:
{
  "completion_message": {
    "role": "assistant",
    "content": "The moon glows softly in the midnight sky,\nA beacon of wonder, as it catches the eye.",
    "stop_reason": "out_of_tokens",
    "tool_calls": []
  },
  "logprobs": null
}
Test with Python
You can also interact with the Llama Stack server using a simple Python script. Below is an example:
1. Activate Conda Environment and Install Required Python Packages
The llama-stack-client library offers a robust and efficient python methods for interacting with the Llama Stack server.
conda activate ollama
pip install llama-stack-client
Note, the client library gets installed by default if you install the server library
2. Create Python Script (test_llama_stack.py)
touch test_llama_stack.py
3. Create a Chat Completion Request in Python
In test_llama_stack.py, write the following code:
from llama_stack_client import LlamaStackClient
# Initialize the client
client = LlamaStackClient(base_url="http://localhost:5051")
# Create a chat completion request
response = client.inference.chat_completion(
    messages=[
        {"role": "system", "content": "You are a friendly assistant."},
        {"role": "user", "content": "Write a two-sentence poem about llama."}
    ],
    model_id=MODEL_NAME,
)
# Print the response
print(response.completion_message.content)
4. Run the Python Script
python test_llama_stack.py
Expected Output:
The moon glows softly in the midnight sky,
A beacon of wonder, as it catches the eye.
With these steps, you should have a functional Llama Stack setup capable of generating text using the specified model. For more detailed information and advanced configurations, refer to some of our documentation below.
This command initializes the model to interact with your local Llama Stack instance.
Next Steps
Explore Other Guides: Dive deeper into specific topics by following these guides:
- Understanding Distribution
- Inference 101
- Local and Cloud Model Toggling 101
- Prompt Engineering
- Chat with Image - LlamaStack Vision API
- Tool Calling: How to and Details
- Memory API: Show Simple In-Memory Retrieval
- Using Safety API in Conversation
- Agents API: Explain Components
Explore Client SDKs: Utilize our client SDKs for various languages to integrate Llama Stack into your applications:
Advanced Configuration: Learn how to customize your Llama Stack distribution by referring to the Building a Llama Stack Distribution guide.
Explore Example Apps: Check out llama-stack-apps for example applications built using Llama Stack.