Stable Diffusion within Open WebUI (20240730)
This post details the build as a container of Automatic1111 and its integration as an image generator option for the “Ollama with Open WebUI” installation.
Linux hosts set up instructions for installing Ollama with the Open WebUI using Dockge, a self-hosted Docker Compose stacks management.
init
: 20240707)services: ollama: image: ollama/ollama:latest container_name: ollama ports: - 11434:11434 volumes: - ./ollama:/root/.ollama - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro command: serve restart: unless-stopped deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: - gpu labels: - "com.centurylinklabs.watchtower.enable=true"
serve
command
asks Ollama to answer API requests, making it available for other tools to use.ollama
stack, we should have access to http://127.0.0.1:11434/
answering with Ollama is running
, which is what is expected: API access is enabled for other tools to use.https://ollama.example.com/
to this HTTP resource, which will become an option for a later section of this writeup.Note: You should have at least 8 GB of RAM available to run the 7B models, 16 GB to run the 13B models, and 32 GB to run the 33B models.
>_ bash
window, ask ollama
to pull some models. For example, ollama pull llama3:8b
, which we can follow by ollama run llama3:8b
and ask it a question./opt/stacks/ollama/ollama/models
directory. Looking into /opt/stacks/ollama/ollama/models/manifests/registry.ollama.ai/library/
we will see the list of models installed locally. Investigating the model directory, we will see the obtained model’s options (7b
, etc).bash
within the running container (obtain the list using docker container ls
)and add more models by running docker exec -it <CONTAINERID> /bin/bash
, then run ollama pull
or ollama run
commands. Similarly, the ollama
command has some sub-commands; in particular, be aware of list
and rm
should you want to clean up some older downloaded models.open-webui
to the already existing ollama
stack.compose.yaml
to communicate with one another. When this is done, services end up on the same private subnetwork, and it is possible to use the service names to communicate (i.e. a service
named ollama
can be accessed using the ollama
name).OLLAMA_HOST
to ask Ollama to listen on all available network interfaces. Because Docker containers operate within an abstracted network environment different from the host's network interfaces, containers are connected to a virtual network interface created by Docker. This interface is typically part of a bridge network, which isolates the container's network from the host's network while allowing communication between containers on the same bridge network (in this case, both services are being started within the same compose.yaml
file).OLLAMA_HOST=0.0.0.0:11434
in this setup, we request Ollama to answer requests beyond localhost
only, and this will allow us to have the open_webui
service talk to ollama
directly.compose.yaml
is as follows:services: ollama: image: ollama/ollama:latest container_name: ollama ports: - 11434:11434 volumes: - ./ollama:/root/.ollama - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro command: serve environment: - OLLAMA_HOST=0.0.0.0:11434 restart: unless-stopped deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: - gpu labels: - "com.centurylinklabs.watchtower.enable=true" open-webui: image: ghcr.io/open-webui/open-webui:cuda container_name: open-webui volumes: - ./open-webui:/app/backend/data - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro ports: - 3030:8080 depends_on: - ollama restart: unless-stopped environment: - OLLAMA_BASE_URL=http://ollama:11434 deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: - gpu labels: - "com.centurylinklabs.watchtower.enable=true"
open-webui
service which depends_on
and communicate with the ollama
service, and listens on port 8080 (but we are exposing it on port 3030), we altered the ollama
stack to add the environment
section: the OLLAMA_HOST
variable requests the service to listen to all interfaces, not just 127.0.0.1
which is only local to the ollama
container.compose.yaml
file gets its own private IP on the private bridge subnet created for the stack. In a terminal, run docker network ls
to see the list of private subnets created by docker compose
to isolate the services from the running host. Except for exposed ports, those communications stay internal to that subnet. The stack name is ollama
(which is also the directory name in /opt/stacks
), ollama_default
is the name of the network to inspect using docker network inspect ollama_default
. In our setup, the subnet is 172.23.0.0/16 and the ollama
container runs on 172.23.0.2/16 while open-webui
is on 172.23.0.3/16.OLLAMA_HOST
variable to be set (i.e. the compose.yaml
from the “Ollama” section is sufficient) but requires the use ofhost.docker.internal
.localhost
(i.e., other exposed services). It resolves to the host's internal IP address within the Docker network. The host-gateway
option is a reserved string used in Docker configurations to determine the host's IP address dynamically.compose.yaml
file:environment: - OLLAMA_BASE_URL=http://host.docker.internal:11434 extra_hosts: - host.docker.internal:host-gateway
open-webui
stack’s compose.yaml
:services: open-webui: image: ghcr.io/open-webui/open-webui:cuda container_name: open-webui volumes: - ./open-webui:/app/backend/data - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro ports: - 3030:8080 restart: unless-stopped environment: - OLLAMA_BASE_URL=http://host.docker.internal:11434 extra_hosts: - host.docker.internal:host-gateway deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: - gpu labels: - "com.centurylinklabs.watchtower.enable=true"
port
: 3030.open-webui
directory in /opt/stacks
, but the tool will only work if the ollama
container has been started before the open-webui
one.https://ollama.example.com/
we can bypass the host.docker.internal
in favor a direct access to the host. The compose.yaml
looks similar to the one in the previous section, but notice the alternate OLLAMA_BASE_URL
:services: open-webui: image: ghcr.io/open-webui/open-webui:cuda container_name: open-webui volumes: - ./open-webui:/app/backend/data - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro ports: - 3030:8080 restart: unless-stopped environment: - OLLAMA_BASE_URL=https://ollama.example.com deploy: resources: reservations: devices: - driver: nvidia count: all capabilities: - gpu labels: - "com.centurylinklabs.watchtower.enable=true"
OLLAMA_BASE_URL
allows us to run the WebUI on another host than the one running the Ollama service, which, by extension, can also be defined as OLLAMA_BASE_URL=http://<IP>:<PORT>
in the absence of a reverse proxy.Admin Creation: The first account created on Open WebUI gains Administrator privileges, controlling user management and system settings.
User Registrations: Subsequent sign-ups start with Pending status, requiring Administrator approval for access.
Privacy and Data Security: All your data, including login details, is locally stored on your device. Open WebUI ensures strict confidentiality and no external requests for enhanced privacy and security.
"WebSearch" in Open WebUI is a powerful feature that lets you perform searches directly through the interface using various search engines.Here's what it provides:
- Integrated Search: No need to leave Open WebUI to use a search engine. Just type your query into the search bar and get results from multiple sources.
- Multiple Engines: Open WebUI supports various search engines like Google, DuckDuckGo, Bing, and others. You can choose your preferred engine or switch between them easily.
- Direct Results: WebSearch pulls results directly from the chosen search engine, so you get the same information you'd find on their websites.
- Relevance and Ranking: Open WebUI aims to present results in a relevant and well-ranked order, making it easier to find what you're looking for.
host.docker.internal:host-gateway
method (it is easy to change this to a reverse proxy url when available)searxng
and just “Save” it; before using it, we need to populate the directory with a folder and three files that will be obtained from Open WebUI’s SearXNG WebSearch documentation at https://docs.openwebui.com/tutorial/web_search#searxng-docker# /opt/stacks is not readable by the default user, we need to become root (temporarily) sudo su cd /opt/stacks/searxng mkdir searxng nano searxng/settings.yml # fill in the content of the file from the documentation # feel free to modify the secret_key value nano searxng/limiter.toml # fill in the content of the file from the documentation nano searxng/uwsgi.ini # fill in the content of the file from the documentation
searxng
stack and use the following for its compose.yaml
:services: searxng: image: searxng/searxng:latest container_name: searxng ports: - 8234:8080 volumes: - ./searxng:/etc/searxng - /etc/timezone:/etc/timezone:ro - /etc/localtime:/etc/localtime:ro restart: always labels: - "com.centurylinklabs.watchtower.enable=true"
open-webui
stack’s compose.yml
:extra_hosts: - host.docker.internal:host-gateway
environment:
section, add:- ENABLE_RAG_WEB_SEARCH=true - RAG_WEB_SEARCH_ENGINE=searxng - RAG_WEB_SEARCH_RESULT_COUNT=3 - RAG_WEB_SEARCH_CONCURRENT_REQUESTS=10 - SEARXNG_QUERY_URL=http://host.docker.internal:8234/search?q=<query>
http://host.docker.internal:8234/search?q=<query>
for the “Query URL”.compose.yaml
: https://docs.openwebui.com/getting-started/env-configurationcuda
container + added WebSearch and SearXNG contentrestart
policy to Ollama container