mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-26 09:15:40 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 2s
				
			Integration Tests / discover-tests (push) Successful in 2s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::milvus) (push) Failing after 17s
				
			Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 19s
				
			Python Package Build Test / build (3.12) (push) Failing after 14s
				
			Test Llama Stack Build / build-custom-container-distribution (push) Failing after 14s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::pgvector) (push) Failing after 15s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 20s
				
			Unit Tests / unit-tests (3.13) (push) Failing after 15s
				
			Test Llama Stack Build / generate-matrix (push) Successful in 16s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::pgvector) (push) Failing after 20s
				
			Test External Providers / test-external-providers (venv) (push) Failing after 17s
				
			Update ReadTheDocs / update-readthedocs (push) Failing after 15s
				
			Test Llama Stack Build / build-single-provider (push) Failing after 21s
				
			Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 18s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 22s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::sqlite-vec) (push) Failing after 25s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::chromadb) (push) Failing after 23s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::milvus) (push) Failing after 26s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::sqlite-vec) (push) Failing after 19s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::faiss) (push) Failing after 28s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::faiss) (push) Failing after 21s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::chromadb) (push) Failing after 23s
				
			Python Package Build Test / build (3.13) (push) Failing after 44s
				
			Test Llama Stack Build / build (push) Failing after 25s
				
			Integration Tests / test-matrix (push) Failing after 46s
				
			Pre-commit / pre-commit (push) Successful in 2m24s
				
			# What does this PR do? Reorganizes the Llama stack webpage into more concise index pages, introduce more of a workflow, and reduce repetition of content. New nav structure so far based on #2637 Further discussions in https://github.com/meta-llama/llama-stack/discussions/2585 **Preview:**  You can also build a full local preview locally **Feedback** Looking for feedback on page titles and general feedback on the new structure **Follow up documentation** I plan on reducing some sections and standardizing some terminology in a follow up PR. More discussions on that in https://github.com/meta-llama/llama-stack/discussions/2585
		
			
				
	
	
		
			193 lines
		
	
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ## OpenAI API Compatibility
 | |
| 
 | |
| ### Server path
 | |
| 
 | |
| Llama Stack exposes an OpenAI-compatible API endpoint at `/v1/openai/v1`. So, for a Llama Stack server running locally on port `8321`, the full url to the OpenAI-compatible API endpoint is `http://localhost:8321/v1/openai/v1`.
 | |
| 
 | |
| ### Clients
 | |
| 
 | |
| You should be able to use any client that speaks OpenAI APIs with Llama Stack. We regularly test with the official Llama Stack clients as well as OpenAI's official Python client.
 | |
| 
 | |
| #### Llama Stack Client
 | |
| 
 | |
| When using the Llama Stack client, set the `base_url` to the root of your Llama Stack server. It will automatically route OpenAI-compatible requests to the right server endpoint for you.
 | |
| 
 | |
| ```python
 | |
| from llama_stack_client import LlamaStackClient
 | |
| 
 | |
| client = LlamaStackClient(base_url="http://localhost:8321")
 | |
| ```
 | |
| 
 | |
| #### OpenAI Client
 | |
| 
 | |
| When using an OpenAI client, set the `base_url` to the `/v1/openai/v1` path on your Llama Stack server.
 | |
| 
 | |
| ```python
 | |
| from openai import OpenAI
 | |
| 
 | |
| client = OpenAI(base_url="http://localhost:8321/v1/openai/v1", api_key="none")
 | |
| ```
 | |
| 
 | |
| Regardless of the client you choose, the following code examples should all work the same.
 | |
| 
 | |
| ### APIs implemented
 | |
| 
 | |
| #### Models
 | |
| 
 | |
| Many of the APIs require you to pass in a model parameter. To see the list of models available in your Llama Stack server:
 | |
| 
 | |
| ```python
 | |
| models = client.models.list()
 | |
| ```
 | |
| 
 | |
| #### Responses
 | |
| 
 | |
| :::{note}
 | |
| The Responses API implementation is still in active development. While it is quite usable, there are still unimplemented parts of the API. We'd love feedback on any use-cases you try that do not work to help prioritize the pieces left to implement. Please open issues in the [meta-llama/llama-stack](https://github.com/meta-llama/llama-stack) GitHub repository with details of anything that does not work.
 | |
| :::
 | |
| 
 | |
| ##### Simple inference
 | |
| 
 | |
| Request:
 | |
| 
 | |
| ```
 | |
| response = client.responses.create(
 | |
|     model="meta-llama/Llama-3.2-3B-Instruct",
 | |
|     input="Write a haiku about coding."
 | |
| )
 | |
| 
 | |
| print(response.output_text)
 | |
| ```
 | |
| Example output:
 | |
| 
 | |
| ```text
 | |
| Pixels dancing slow
 | |
| Syntax whispers secrets sweet
 | |
| Code's gentle silence
 | |
| ```
 | |
| 
 | |
| ##### Structured Output
 | |
| 
 | |
| Request:
 | |
| 
 | |
| ```python
 | |
| response = client.responses.create(
 | |
|     model="meta-llama/Llama-3.2-3B-Instruct",
 | |
|     input=[
 | |
|         {
 | |
|             "role": "system",
 | |
|             "content": "Extract the participants from the event information.",
 | |
|         },
 | |
|         {
 | |
|             "role": "user",
 | |
|             "content": "Alice and Bob are going to a science fair on Friday.",
 | |
|         },
 | |
|     ],
 | |
|     text={
 | |
|         "format": {
 | |
|             "type": "json_schema",
 | |
|             "name": "participants",
 | |
|             "schema": {
 | |
|                 "type": "object",
 | |
|                 "properties": {
 | |
|                     "participants": {"type": "array", "items": {"type": "string"}}
 | |
|                 },
 | |
|                 "required": ["participants"],
 | |
|             },
 | |
|         }
 | |
|     },
 | |
| )
 | |
| print(response.output_text)
 | |
| ```
 | |
| 
 | |
| Example output:
 | |
| 
 | |
| ```text
 | |
| { "participants": ["Alice", "Bob"] }
 | |
| ```
 | |
| 
 | |
| #### Chat Completions
 | |
| 
 | |
| ##### Simple inference
 | |
| 
 | |
| Request:
 | |
| 
 | |
| ```python
 | |
| chat_completion = client.chat.completions.create(
 | |
|     model="meta-llama/Llama-3.2-3B-Instruct",
 | |
|     messages=[{"role": "user", "content": "Write a haiku about coding."}],
 | |
| )
 | |
| 
 | |
| print(chat_completion.choices[0].message.content)
 | |
| ```
 | |
| 
 | |
| Example output:
 | |
| 
 | |
| ```text
 | |
| Lines of code unfold
 | |
| Logic flows like a river
 | |
| Code's gentle beauty
 | |
| ```
 | |
| 
 | |
| ##### Structured Output
 | |
| 
 | |
| Request:
 | |
| 
 | |
| ```python
 | |
| chat_completion = client.chat.completions.create(
 | |
|     model="meta-llama/Llama-3.2-3B-Instruct",
 | |
|     messages=[
 | |
|         {
 | |
|             "role": "system",
 | |
|             "content": "Extract the participants from the event information.",
 | |
|         },
 | |
|         {
 | |
|             "role": "user",
 | |
|             "content": "Alice and Bob are going to a science fair on Friday.",
 | |
|         },
 | |
|     ],
 | |
|     response_format={
 | |
|         "type": "json_schema",
 | |
|         "json_schema": {
 | |
|             "name": "participants",
 | |
|             "schema": {
 | |
|                 "type": "object",
 | |
|                 "properties": {
 | |
|                     "participants": {"type": "array", "items": {"type": "string"}}
 | |
|                 },
 | |
|                 "required": ["participants"],
 | |
|             },
 | |
|         },
 | |
|     },
 | |
| )
 | |
| 
 | |
| print(chat_completion.choices[0].message.content)
 | |
| ```
 | |
| 
 | |
| Example output:
 | |
| 
 | |
| ```text
 | |
| { "participants": ["Alice", "Bob"] }
 | |
| ```
 | |
| 
 | |
| #### Completions
 | |
| 
 | |
| ##### Simple inference
 | |
| 
 | |
| Request:
 | |
| 
 | |
| ```python
 | |
| completion = client.completions.create(
 | |
|     model="meta-llama/Llama-3.2-3B-Instruct", prompt="Write a haiku about coding."
 | |
| )
 | |
| 
 | |
| print(completion.choices[0].text)
 | |
| ```
 | |
| 
 | |
| Example output:
 | |
| 
 | |
| ```text
 | |
| Lines of code unfurl
 | |
| Logic whispers in the dark
 | |
| Art in hidden form
 | |
| ```
 |