Go to file
Timothy J. Baek abfcceecef refac
2024-04-10 00:46:09 -07:00
.github Update docker-build.yaml 2024-04-08 13:36:50 -07:00
backend refac 2024-04-10 00:46:09 -07:00
docs added simplified + traditional chinese, updates uk keys, changed standart language code format to xx-XX 2024-03-14 12:10:04 +01:00
kubernetes remove deprecated /api from ollama base url 2024-04-04 23:57:32 +02:00
src refac 2024-04-10 00:46:09 -07:00
static Do not use hardcoded manifest.json 2024-04-02 16:08:10 -03:00
.dockerignore fix: default openai api value 2024-03-06 20:25:24 -08:00
.env.example Use locally bundled version of the LiteLLM cost map json 2024-04-05 16:27:31 -06:00
.eslintignore
.eslintrc.cjs
.gitattributes fixed Docker problem some users experienced 2024-02-13 12:46:21 +01:00
.gitignore Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
.npmrc
.prettierignore
.prettierrc
bun.lockb first draft 2024-02-22 11:54:55 +01:00
Caddyfile.localhost
CHANGELOG.md Update CHANGELOG.md 2024-04-03 21:37:15 -07:00
confirm_remove.sh feat: implemented user confirmation for safe removal of containers and volumes in Makefile 2024-02-24 09:02:18 +01:00
demo.gif Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
docker-compose.amdgpu.yaml Add variables 2024-04-05 23:46:20 -04:00
docker-compose.api.yaml
docker-compose.data.yaml
docker-compose.gpu.yaml
docker-compose.yaml Add Docker tag variables 2024-04-05 23:48:16 -04:00
Dockerfile Update Dockerfile 2024-04-08 01:40:03 -07:00
i18next-parser.config.ts Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
INSTALLATION.md rename 2024-02-17 00:07:43 -08:00
LICENSE
Makefile Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
package-lock.json chore: npm audit fix 2024-04-03 10:26:24 -07:00
package.json chore: npm audit fix 2024-04-03 10:26:24 -07:00
postcss.config.js
README.md README instructions and build fixes 2024-04-03 11:34:25 +02:00
run-compose.sh Update run-compose.sh 2024-03-01 17:45:32 +01:00
run-ollama-docker.sh fix: run-ollama-docker.sh 2024-01-29 15:38:56 -08:00
run.sh Update run.sh 2024-02-19 11:43:53 -08:00
svelte.config.js Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
tailwind.config.js Revert "Merge Updates & Dockerfile improvements" (#3) 2024-04-02 11:28:04 +02:00
TROUBLESHOOTING.md refac: OLLAMA_API_BASE_URL deprecated 2024-03-06 11:44:00 -08:00
tsconfig.json
update_ollama_models.sh fix: update Makefile and rename script for open-webui integration 2024-02-24 07:51:27 +01:00
vite.config.ts Update vite.config.ts 2024-02-23 01:08:34 -08:00

Open WebUI (Formerly Ollama WebUI) 👋

GitHub stars GitHub forks GitHub watchers GitHub repo size GitHub language count GitHub top language GitHub last commit Hits Discord

Open WebUI is an extensible, feature-rich, and user-friendly self-hosted WebUI designed to operate entirely offline. It supports various LLM runners, including Ollama and OpenAI-compatible APIs. For more information, be sure to check out our Open WebUI Documentation.

Open WebUI Demo

Features

  • 🖥️ Intuitive Interface: Our chat interface takes inspiration from ChatGPT, ensuring a user-friendly experience.

  • 📱 Responsive Design: Enjoy a seamless experience on both desktop and mobile devices.

  • Swift Responsiveness: Enjoy fast and responsive performance.

  • 🚀 Effortless Setup: Install seamlessly using Docker or Kubernetes (kubectl, kustomize or helm) for a hassle-free experience.

  • 💻 Code Syntax Highlighting: Enjoy enhanced code readability with our syntax highlighting feature.

  • ✒️🔢 Full Markdown and LaTeX Support: Elevate your LLM experience with comprehensive Markdown and LaTeX capabilities for enriched interaction.

  • 📚 Local RAG Integration: Dive into the future of chat interactions with the groundbreaking Retrieval Augmented Generation (RAG) support. This feature seamlessly integrates document interactions into your chat experience. You can load documents directly into the chat or add files to your document library, effortlessly accessing them using # command in the prompt. In its alpha phase, occasional issues may arise as we actively refine and enhance this feature to ensure optimal performance and reliability.

  • 🌐 Web Browsing Capability: Seamlessly integrate websites into your chat experience using the # command followed by the URL. This feature allows you to incorporate web content directly into your conversations, enhancing the richness and depth of your interactions.

  • 📜 Prompt Preset Support: Instantly access preset prompts using the / command in the chat input. Load predefined conversation starters effortlessly and expedite your interactions. Effortlessly import prompts through Open WebUI Community integration.

  • 👍👎 RLHF Annotation: Empower your messages by rating them with thumbs up and thumbs down, facilitating the creation of datasets for Reinforcement Learning from Human Feedback (RLHF). Utilize your messages to train or fine-tune models, all while ensuring the confidentiality of locally saved data.

  • 🏷️ Conversation Tagging: Effortlessly categorize and locate specific chats for quick reference and streamlined data collection.

  • 📥🗑️ Download/Delete Models: Easily download or remove models directly from the web UI.

  • ⬆️ GGUF File Model Creation: Effortlessly create Ollama models by uploading GGUF files directly from the web UI. Streamlined process with options to upload from your machine or download GGUF files from Hugging Face.

  • 🤖 Multiple Model Support: Seamlessly switch between different chat models for diverse interactions.

  • 🔄 Multi-Modal Support: Seamlessly engage with models that support multimodal interactions, including images (e.g., LLava).

  • 🧩 Modelfile Builder: Easily create Ollama modelfiles via the web UI. Create and add characters/agents, customize chat elements, and import modelfiles effortlessly through Open WebUI Community integration.

  • ⚙️ Many Models Conversations: Effortlessly engage with various models simultaneously, harnessing their unique strengths for optimal responses. Enhance your experience by leveraging a diverse set of models in parallel.

  • 💬 Collaborative Chat: Harness the collective intelligence of multiple models by seamlessly orchestrating group conversations. Use the @ command to specify the model, enabling dynamic and diverse dialogues within your chat interface. Immerse yourself in the collective intelligence woven into your chat environment.

  • 🔄 Regeneration History Access: Easily revisit and explore your entire regeneration history.

  • 📜 Chat History: Effortlessly access and manage your conversation history.

  • 📤📥 Import/Export Chat History: Seamlessly move your chat data in and out of the platform.

  • 🗣️ Voice Input Support: Engage with your model through voice interactions; enjoy the convenience of talking to your model directly. Additionally, explore the option for sending voice input automatically after 3 seconds of silence for a streamlined experience.

  • ⚙️ Fine-Tuned Control with Advanced Parameters: Gain a deeper level of control by adjusting parameters such as temperature and defining your system prompts to tailor the conversation to your specific preferences and needs.

  • 🎨🤖 Image Generation Integration: Seamlessly incorporate image generation capabilities using AUTOMATIC1111 API (local) and DALL-E, enriching your chat experience with dynamic visual content.

  • 🤝 OpenAI API Integration: Effortlessly integrate OpenAI-compatible API for versatile conversations alongside Ollama models. Customize the API Base URL to link with LMStudio, Mistral, OpenRouter, and more.

  • Multiple OpenAI-Compatible API Support: Seamlessly integrate and customize various OpenAI-compatible APIs, enhancing the versatility of your chat interactions.

  • 🔗 External Ollama Server Connection: Seamlessly link to an external Ollama server hosted on a different address by configuring the environment variable.

  • 🔀 Multiple Ollama Instance Load Balancing: Effortlessly distribute chat requests across multiple Ollama instances for enhanced performance and reliability.

  • 👥 Multi-User Management: Easily oversee and administer users via our intuitive admin panel, streamlining user management processes.

  • 🔐 Role-Based Access Control (RBAC): Ensure secure access with restricted permissions; only authorized individuals can access your Ollama, and exclusive model creation/pulling rights are reserved for administrators.

  • 🔒 Backend Reverse Proxy Support: Bolster security through direct communication between Open WebUI backend and Ollama. This key feature eliminates the need to expose Ollama over LAN. Requests made to the '/ollama/api' route from the web UI are seamlessly redirected to Ollama from the backend, enhancing overall system security.

  • 🌐🌍 Multilingual Support: Experience Open WebUI in your preferred language with our internationalization (i18n) support. Join us in expanding our supported languages! We're actively seeking contributors!

  • 🌟 Continuous Updates: We are committed to improving Open WebUI with regular updates and new features.

🔗 Also Check Out Open WebUI Community!

Don't forget to explore our sibling project, Open WebUI Community, where you can discover, download, and explore customized Modelfiles. Open WebUI Community offers a wide range of exciting possibilities for enhancing your chat interactions with Open WebUI! 🚀

How to Install 🚀

Note

Please note that for certain Docker environments, additional configurations might be needed. If you encounter any connection issues, our detailed guide on Open WebUI Documentation is ready to assist you.

Quick Start with Docker 🐳

Important

When using Docker to install Open WebUI, make sure to include the -v open-webui:/app/backend/data in your Docker command. This step is crucial as it ensures your database is properly mounted and prevents any loss of data.

  • If Ollama is on your computer, use this command:

    docker run -d -p 3000:8080 --add-host=host.docker.internal:host-gateway -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
    
  • If Ollama is on a Different Server, use this command:

  • To connect to Ollama on another server, change the OLLAMA_BASE_URL to the server's URL:

    docker run -d -p 3000:8080 -e OLLAMA_BASE_URL=https://example.com -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
    
  • After installation, you can access Open WebUI at http://localhost:3000. Enjoy! 😄

  • If you want to customize your build with additional args, use this commands:

    Note

    If you only want to use Open WebUI with Ollama included or CUDA acelleration it's recomented to use our official images with the tags :cuda or :with-ollama If you want a combination of both or more customisation options like a different embedding model and/or CUDA version you need to build the image yourself following the instructions below.

    For the build:

    docker build -t open-webui
    

    Optional build ARGS (use them in the docker build command below if needed):

    e.g.
    
    --build-arg="USE_EMBEDDING_MODEL=intfloat/multilingual-e5-large"
    

    For "intfloat/multilingual-e5-large" custom embedding model (default is all-MiniLM-L6-v2), only works with sentence transforer models. Current Leaderbord of embedding models.

    --build-arg="USE_OLLAMA=true"
    

    For including ollama in the image.

    --build-arg="USE_CUDA=true"
    

    To use CUDA exeleration for the embedding and whisper models.

    Note

    You need to install the Nvidia CUDA container toolkit on your machine to be able to set CUDA as the Docker engine. Only works with Linux - use WSL for Windows!

    --build-arg="USE_CUDA_VER=cu117"
    

    For CUDA 11 (default is CUDA 12)

    To run the image:

    • If you DID NOT use the USE_CUDA=true build ARG, use this command:
      docker run -d -p 3000:8080 -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
    
    • If you DID use the USE_CUDA=true build ARG, use this command:
      docker run --gpus all -d -p 3000:8080 -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
    

Open WebUI: Server Connection Error

If you're experiencing connection issues, its often due to the WebUI docker container not being able to reach the Ollama server at 127.0.0.1:11434 (host.docker.internal:11434) inside the container . Use the --network=host flag in your docker command to resolve this. Note that the port changes from 3000 to 8080, resulting in the link: http://localhost:8080.

Example Docker Command:

docker run -d --network=host -v open-webui:/app/backend/data -e OLLAMA_BASE_URL=http://127.0.0.1:11434 --name open-webui --restart always ghcr.io/open-webui/open-webui:main

Other Installation Methods

We offer various installation alternatives, including non-Docker methods, Docker Compose, Kustomize, and Helm. Visit our Open WebUI Documentation or join our Discord community for comprehensive guidance.

Troubleshooting

Encountering connection issues? Our Open WebUI Documentation has got you covered. For further assistance and to join our vibrant community, visit the Open WebUI Discord.

Keeping Your Docker Installation Up-to-Date

In case you want to update your local Docker installation to the latest version, you can do it with Watchtower:

docker run --rm --volume /var/run/docker.sock:/var/run/docker.sock containrrr/watchtower --run-once open-webui

In the last part of the command, replace open-webui with your container name if it is different.

Moving from Ollama WebUI to Open WebUI

Check our Migration Guide available in our Open WebUI Documentation.

What's Next? 🌟

Discover upcoming features on our roadmap in the Open WebUI Documentation.

Supporters

A big shoutout to our amazing supporters who's helping to make this project possible! 🙏

Platinum Sponsors 🤍

  • We're looking for Sponsors!

Acknowledgments

Special thanks to Prof. Lawrence Kim and Prof. Nick Vincent for their invaluable support and guidance in shaping this project into a research endeavor. Grateful for your mentorship throughout the journey! 🙌

License 📜

This project is licensed under the MIT License - see the LICENSE file for details. 📄

Support 💬

If you have any questions, suggestions, or need assistance, please open an issue or join our Open WebUI Discord community to connect with us! 🤝

Star History

Star History Chart

Created by Timothy J. Baek - Let's make Open Web UI even more amazing together! 💪