Skip to content

Commit 11403bd

Browse files
committed
Add explicit docs for consuming OKP
1 parent 5b6d64d commit 11403bd

1 file changed

Lines changed: 206 additions & 0 deletions

File tree

docs/okp_guide.md

Lines changed: 206 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,206 @@
1+
# OKP Deployment and Configuration Guide
2+
3+
This document explains how to deploy the Offline Knowledge Portal (OKP) as a RAG source and configure Lightspeed Stack and Llama Stack to use it. You will:
4+
5+
* Configure Lightspeed Stack for OKP (inline or tool RAG)
6+
* Run the configuration enrichment step
7+
* Deploy and verify the OKP Solr service
8+
* Install dependencies and launch Lightspeed Stack
9+
* Confirm the end-to-end stack with a sample query
10+
11+
For general RAG concepts, BYOK vector stores, and manual Llama Stack configuration, see the [RAG Configuration Guide](rag_guide.md).
12+
13+
---
14+
15+
## Table of Contents
16+
17+
* [Introduction](#introduction)
18+
* [Prerequisites](#prerequisites)
19+
* [Step 1: Launch OKP](#step-1-launch-okp)
20+
* [Step 2: Setup llamamstack config environment variables](#step-2-setup-llamamstack-config-environment-variables)
21+
* [Step 3: Install Lightspeed Stack Dependencies](#step-3-install-lightspeed-stack-dependencies)
22+
* [Step 4: Configure Lightspeed Stack](#step-4-configure-lightspeed-stack)
23+
* [Step 5: Run Configuration Enrichment](#step-5-run-configuration-enrichment)
24+
* [Step 6: Launch Lightspeed Stack](#step-6-launch-lightspeed-stack)
25+
* [Step 7: Verify the Stack](#step-7-verify-the-stack)
26+
27+
---
28+
29+
## Introduction
30+
31+
OKP (Offline Knowledge Portal) provides a Solr-backed RAG source that Lightspeed Stack can use for both **Inline RAG** (context injected before the LLM request) and **Tool RAG** (context retrieved on demand via the `file_search` tool). This guide walks through deploying the OKP container, enriching your Llama Stack config from Lightspeed Stack settings, and validating that queries return referenced chunks.
32+
33+
---
34+
35+
## Prerequisites
36+
37+
* [lightspeed-stack repository](https://github.com/lightspeed-core/lightspeed-stack) cloned and ready to run
38+
* [lightspeed-providers repository](https://github.com/lightspeed-core/lightspeed-providers) repository cloned
39+
* [Podman](https://podman.io/) (or Docker) to run the OKP image
40+
* [uv](https://docs.astral.sh/uv/) for Python dependency management
41+
* An OpenAI API key (for inference when using OpenAI in your run config)
42+
43+
---
44+
45+
## Step 1: Launch OKP
46+
47+
> **Warning:** The image referenced below is a **prototype**. The official OKP RAG image is expected in **late March / early April** of 2026.
48+
49+
Start the OKP RAG service with Podman:
50+
51+
```bash
52+
podman run --rm -d -p 8983:8080 images.paas.redhat.com/offline-kbase/rhokp-rag:mar-9-2026
53+
```
54+
55+
> **Note:** Remove `-d` to run in the foreground.
56+
57+
* The service listens on **port 8983** on the host (mapped from 8080 in the container).
58+
* Confirm it is running by opening in a browser or with `curl`:
59+
60+
```bash
61+
curl -s http://localhost:8983
62+
```
63+
64+
Or visit: **http://localhost:8983**
65+
66+
---
67+
68+
## Step 2: Setup llamastack config environment variables
69+
70+
Set the required environment variables. The external providers path must point to the `external_providers` content inside the [lightspeed-providers](https://github.com/lightspeed-core/lightspeed-providers/tree/main/lightspeed_stack_providers/) repository:
71+
72+
```bash
73+
export EXTERNAL_PROVIDERS_DIR=../lightspeed-providers/resources/external_providers
74+
export OPENAI_API_KEY=<your-openai-api-key>
75+
```
76+
77+
Adjust `EXTERNAL_PROVIDERS_DIR` if your lightspeed-providers repo is in a different location relative to your lightspeed-stack directory.
78+
79+
---
80+
81+
## Step 3: Install Lightspeed Stack Dependencies
82+
83+
Then install dependencies and custom providers:
84+
85+
```bash
86+
uv sync --group dev --group llslibdev
87+
uv pip install -e ../lightspeed-providers # Path to lightspeed-providers repo
88+
```
89+
90+
* **`uv sync`**: Installs project and dev/llslibdev groups so that the app and tooling run correctly.
91+
* **`uv pip install -e ../lightspeed-providers`**: Installs the lightspeed stack providers from the local clone of the repository. Adjust the directory path as needed.
92+
93+
> **Note:** Running `uv sync` will remove the lightspeed-providers dependency installed by the `uv pip install` command, so you will need to rerun the `uv pip install` command if you rerun `uv sync`.
94+
95+
---
96+
97+
## Step 4: Configure Lightspeed Stack
98+
99+
### Enable OKP in Lightspeed Stack
100+
Edit your Lightspeed Stack config file (e.g. `lightspeed-stack.yaml`) and add the following top-level sections so that OKP is used for either inline or tool RAG:
101+
102+
Inline RAG:
103+
```yaml
104+
# RAG configuration
105+
rag:
106+
inline:
107+
- okp
108+
okp:
109+
offline: true
110+
```
111+
112+
Tool RAG:
113+
```yaml
114+
# RAG configuration
115+
rag:
116+
tool:
117+
- okp
118+
okp:
119+
offline: true
120+
```
121+
122+
* **`rag.inline`** and **`rag.tool`**: Enable OKP as the RAG source for inline context injection and for the RAG tool. Tool rag means the LLM will be provided a search tool it can choose to invoke to find relevant content and augment the user prompt. The tool may or may not be invoked. Inline means a rag search and prompt augmentation will always occur.
123+
* **`okp.offline`**: When `true`, source URLs use `parent_id` (offline/Mimir-style). When `false`, use `reference_url` (online).
124+
125+
If you want to filter the docs to a specific product, you can include a query filter such as:
126+
127+
```yaml
128+
okp:
129+
offline: true
130+
chunk_filter_query: "product:*openshift*"
131+
```
132+
133+
When you launch Lightspeed stack it will augment the Llamastack run.yaml with configuration for OKP.
134+
135+
### Configure Lightspeed Stack for library mode
136+
137+
For the simplest local development, configure `lightspeed-stack.yaml` to consume Llama Stack in library mode:
138+
139+
```yaml
140+
llama_stack:
141+
...
142+
use_as_library_client: true
143+
library_client_config_path: run.yaml
144+
# Comment these lines out if present
145+
# url: http://lama-stack:87321
146+
# api_key: xyzzy
147+
...
148+
```
149+
150+
---
151+
152+
## Step 5: Launch Lightspeed Stack
153+
154+
Then launch Lightspeed Stack using your Lightspeed Stack config(`lightspeed-stack.yaml`) which references the provided default Llamastack config file (`run.yaml`):
155+
156+
```bash
157+
make run
158+
```
159+
160+
Lightspeed Stack has launched successfully and is available when you see this log output:
161+
162+
```log
163+
INFO 2026-03-17 11:20:31,347 uvicorn.error:62 uncategorized: Application startup complete.
164+
INFO 2026-03-17 11:20:31,349 uvicorn.error:224 uncategorized: Uvicorn running on http://0.0.0.0:8080 (Press CTRL+C to quit)
165+
```
166+
167+
> **Note:** Lightspeed stack will automatically enrich the llamastack configuration to add the necessary providers/resources for referencing OKP. This assumes your OKP instance is running on localhost:8983. If you need a different OKP url, you will need to run `uv run src/llama_stack_configuration.py -c lightspeed-stack.yaml -i run.yaml -o run_enriched.yaml` to generate the llamastack configuration, edit the `solr_url` value in that file, and then edit your lightspeed stack configuration to point to the enriched llamastack config file by setting `library_client_config_path: run_enriched.yaml`.
168+
169+
---
170+
171+
## Step 6: Verify the Stack
172+
173+
Confirm that the full stack (Lightspeed Stack + Llama Stack + OKP) is working by sending a query and checking that the response includes referenced chunks from OKP:
174+
175+
```bash
176+
curl -sX POST http://localhost:8080/v1/query \
177+
-H "Content-Type: application/json" \
178+
-d '{"query": "configure remote desktop using gnome"}' | jq .
179+
```
180+
181+
* Adjust the URL and port if your Lightspeed Stack API is exposed elsewhere.
182+
* In the JSON response, look for `rag_chunks` that indicate OKP/Solr results were retrieved.
183+
184+
Example response excerpt:
185+
```json
186+
"rag_chunks": [
187+
{
188+
"content": "You can connect from a Red Hat Enterprise Linux client to a remote desktop server by using the\n**Connections**\napplication. The connection depends on the remote server configuration.\n**Prerequisites**\n- Desktop sharing or remote login is enabled on the server. For more information, see [Enabling desktop sharing on the server by using GNOME](#enabling-desktop-sharing-on-the-server-by-using-gnome) or [Configuring GNOME remote login](#configuring-gnome-remote-login) .\n- For desktop sharing, a user is logged in to the GNOME graphical session on the server.\n- The `gnome-connections` package is installed on the client.\n**Procedure**\n1. On the client, launch the **Connections** application.\n2. Click the + button in the top bar to open a new connection.\n4. Enter the IP address of the server.\n5. Choose the connection type based on the operating system you want to connect to: Remote Desktop Protocol (RDP) Use RDP for connecting to Windows and RHEL 10 servers. Virtual Network Computing (VNC) Use VNC for connecting to servers with RHEL 9 and previous versions.\n6. Click Connect .\n**Verification**\n1. On the client, check that you can see the shared server desktop.\n2. On the server, a screen sharing indicator appears on the right side of the top panel: You can control screen sharing in the **System** menu of the server.",
189+
"source": "okp",
190+
"score": 826.40784,
191+
"attributes": {
192+
"doc_url": "https://mimir.corp.redhat.com/documentation/en-us/red_hat_enterprise_linux/10/html-single/administering_rhel_by_using_the_gnome_desktop_environment/index",
193+
"document_id": "/documentation/en-us/red_hat_enterprise_linux/10/html-single/administering_rhel_by_using_the_gnome_desktop_environment/index"
194+
}
195+
}
196+
],
197+
```
198+
199+
> **Note:** The first time you query the system the response may take additional time because it must first download the necessary embedding model to perform the vector search.
200+
201+
If you see no RAG context, verify:
202+
203+
1. OKP is up at http://localhost:8983
204+
2. `lightspeed-stack.yaml` has `okp` under `rag.inline` and/or `rag.tool` as in Step 4
205+
206+
---

0 commit comments

Comments
 (0)