Skip to content

Latest commit

 

History

History
197 lines (142 loc) · 4.98 KB

README.md

File metadata and controls

197 lines (142 loc) · 4.98 KB

Setting Up Development Environment for Arch Linux

Install Essential Packages

Install Essential Packages

  1. Install core utilities and development tools:
pacman -S gcc make man-db bluez bluez-utils unzip fish xclip stow git git-delta base-devel nitrogen docker fish pavucontrol alacritty
  1. Powerful task runner, version and env management tool for NodeJS, Python, Rust and more.
curl https://mise.run | sh

# install  Arch User Repository helper
mise use -g yay
# you might want to install other tools per user
cat ~/.config/mise/config.toml
[tools]
glow = "latest"
fzf = "latest"
eza = "latest"
zellij = "latest"
zoxide = "latest"
fd = "latest"
ripgrep = "latest"
starship = "latest"
bat = "latest"
pnpm = "latest"
yay = "latest"
usage = "latest"
python = "latest"
deno = "latest"
bun = "latest"
go = "latest"
bottom = "latest"
dust = "latest"
neovim = "latest"
node = "latest"
rust = "latest"

[settings]
experimental = true
  1. Install the necessary fonts for the system and terminal, including regular, nerd, and emoji fonts:
yay -S --noconfirm ttf-jetbrains-mono-nerd noto-fonts noto-fonts-emoji
# if you need chinese/japanese/korean support: yay -S noto-fonts-cjk
fc-cache -vf
Setting up Docker and Ollama

Setting up Docker and Ollama

  1. Avoid sudo for Docker commands:
# add your user to a docker group
sudo usermod -aG docker $USER
  1. Install NVIDIA Container Toolkit (if applicable):
yay -S nvidia-container-toolkit
sudo nvidia-ctk runtime configure --runtime=docker
sudo systemctl restart docker
  1. Run Ollama inside a Docker container with Open WebUI
  • Run Ollama container
docker run -d --gpus=all -v ollama:/root/.ollama -p 11434:11434 --name ollama ollama/ollama
  • Check if Ollama is up and running
curl -i http://localhost:11434/
HTTP/1.1 200 OK
Content-Type: text/plain; charset=utf-8
Date: Thu, 05 Sep 2024 14:04:02 GMT
Content-Length: 17

Ollama is running
  • Run Open WebUI container

    The --add-host=host.docker.internal:host-gateway flag enables communication between containers using the host's IP address. Will need it to communicate with TTS service later.

docker run -d -p 3000:8080 --gpus all --add-host=host.docker.internal:host-gateway -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:cuda
  • Open the WebUI

    http://localhost:3000/

  1. Run a model (codegemma ❤️)

    CodeGemma is a collection of powerful, lightweight models that can perform a variety of coding tasks like fill-in-the-middle code completion, code generation, natural language understanding, mathematical reasoning, and instruction following.

    • instruct a 7b instruction-tuned variant for natural language-to-code chat and instruction following
    • code a 7b pretrained variant that specializes in code completion and generation from code prefixes and/or suffixes
    • 2b a state of the art 2B pretrained variant that provides up to 2x faster code completion
docker exec -it ollama ollama run codegemma:instruct
  1. Move Docker root directory (optional): You might want to move Docker root to a different volume to save the system disk space

    I moved Docker root directory to the /home, in my case it is mounted to a separate volume:

# Stop Docker services
sudo systemctl stop docker  docker.socket containerd
# Create a new directory (replace `/home/user/new_dir` with your desired location) 
sudo mkdir -p /home/user/new_dir
sudo mv /var/lib/docker /home/user/new_dir
  • Configure Docker root indaemon.json:
sudo vim /etc/docker/daemon.json
{
   "data-root": "/home/user/new_dir",
   "runtimes": {
      "nvidia": {
         "args": [],
         "path": "nvidia-container-runtime"
      }
    }
}
  • Restart Docker services for the changes to take effect:
sudo systemctl restart docker docker.socket containerd
  • Validate new Docker root location:
docker info -f '{{ .DockerRootDir}}'
  1. Integrating openedai-speech TTS into Open WebUI
# expose it throught host.docker.internal:8000 so Open WebUI can access it
docker run -d --gpus=all -p 8000:8000 --add-host=host.docker.internal:host-gateway -v tts-voices:/app/voices -v tts-config:/app/config --name openedai-speech ghcr.io/matatonic/openedai-speech:latest
  • Open the Open WebUI settings and navigate to the TTS Settings under Admin Panel > Settings > Audio.

    Text-to-Speech Engine: OpenAI API Base URL: http://host.docker.internal:8000/v1 API Key: anykey (note: this is a dummy API key, as openedai-speech doesn't require an API key; you can use whatever for this field)

  • To make sure those 3 containers start automatically on Docker service start/restart

docker update --restart=always ollama openedai-speech open-webui

open web ui tts settings