From 3bade04e10fae0db1b0a62ec0d5d9883a6f3c3bf Mon Sep 17 00:00:00 2001 From: Patrick Devine Date: Tue, 21 May 2024 15:30:09 -0700 Subject: [PATCH] doc updates for the faq/troubleshooting (#4565) --- docs/faq.md | 93 ++++++++++++-------- docs/troubleshooting.md | 190 ++++++++++++++++++---------------------- 2 files changed, 141 insertions(+), 142 deletions(-) diff --git a/docs/faq.md b/docs/faq.md index 22bd4da7..b50a3138 100644 --- a/docs/faq.md +++ b/docs/faq.md @@ -6,7 +6,7 @@ Ollama on macOS and Windows will automatically download updates. Click on the ta On Linux, re-run the install script: -``` +```shell curl -fsSL https://ollama.com/install.sh | sh ``` @@ -30,7 +30,7 @@ To change this when using `ollama run`, use `/set parameter`: When using the API, specify the `num_ctx` parameter: -``` +```shell curl http://localhost:11434/api/generate -d '{ "model": "llama3", "prompt": "Why is the sky blue?", @@ -40,6 +40,21 @@ curl http://localhost:11434/api/generate -d '{ }' ``` +## How can I tell if my model was loaded onto the GPU? + +Use the `ollama ps` command to see what models are currently loaded into memory. + +```shell +ollama ps +NAME ID SIZE PROCESSOR UNTIL +llama3:70b bcfb190ca3a7 42 GB 100% GPU 4 minutes from now +``` + +The `Processor` column will show which memory the model was loaded in to: +* `100% GPU` means the model was loaded entirely into the GPU +* `100% CPU` means the model was loaded entirely in system memory +* `48%/52% CPU/GPU` means the model was loaded partially onto both the GPU and into system memory + ## How do I configure Ollama server? Ollama server can be configured with environment variables. @@ -94,6 +109,34 @@ On Windows, Ollama inherits your user and system environment variables. 6. Start the Ollama application from the Windows Start menu. +## How do I use Ollama behind a proxy? + +Ollama is compatible with proxy servers if `HTTP_PROXY` or `HTTPS_PROXY` are configured. When using either variables, ensure it is set where `ollama serve` can access the values. When using `HTTPS_PROXY`, ensure the proxy certificate is installed as a system certificate. Refer to the section above for how to use environment variables on your platform. + +### How do I use Ollama behind a proxy in Docker? + +The Ollama Docker container image can be configured to use a proxy by passing `-e HTTPS_PROXY=https://proxy.example.com` when starting the container. + +Alternatively, the Docker daemon can be configured to use a proxy. Instructions are available for Docker Desktop on [macOS](https://docs.docker.com/desktop/settings/mac/#proxies), [Windows](https://docs.docker.com/desktop/settings/windows/#proxies), and [Linux](https://docs.docker.com/desktop/settings/linux/#proxies), and Docker [daemon with systemd](https://docs.docker.com/config/daemon/systemd/#httphttps-proxy). + +Ensure the certificate is installed as a system certificate when using HTTPS. This may require a new Docker image when using a self-signed certificate. + +```dockerfile +FROM ollama/ollama +COPY my-ca.pem /usr/local/share/ca-certificates/my-ca.crt +RUN update-ca-certificates +``` + +Build and run this image: + +```shell +docker build -t ollama-with-ca . +docker run -d -e HTTPS_PROXY=https://my.proxy.example.com -p 11434:11434 ollama-with-ca +``` + +## Does Ollama send my prompts and answers back to ollama.com? + +No. Ollama runs locally, and conversation data does not leave your machine. ## How can I expose Ollama on my network? @@ -120,7 +163,7 @@ server { Ollama can be accessed using a range of tools for tunneling tools. For example with Ngrok: -``` +```shell ngrok http 11434 --host-header="localhost:11434" ``` @@ -128,7 +171,7 @@ ngrok http 11434 --host-header="localhost:11434" To use Ollama with Cloudflare Tunnel, use the `--url` and `--http-host-header` flags: -``` +```shell cloudflared tunnel --url http://localhost:11434 --http-host-header="localhost:11434" ``` @@ -150,39 +193,10 @@ If a different directory needs to be used, set the environment variable `OLLAMA_ Refer to the section [above](#how-do-i-configure-ollama-server) for how to set environment variables on your platform. -## Does Ollama send my prompts and answers back to ollama.com? - -No. Ollama runs locally, and conversation data does not leave your machine. - ## How can I use Ollama in Visual Studio Code? There is already a large collection of plugins available for VSCode as well as other editors that leverage Ollama. See the list of [extensions & plugins](https://github.com/ollama/ollama#extensions--plugins) at the bottom of the main repository readme. -## How do I use Ollama behind a proxy? - -Ollama is compatible with proxy servers if `HTTP_PROXY` or `HTTPS_PROXY` are configured. When using either variables, ensure it is set where `ollama serve` can access the values. When using `HTTPS_PROXY`, ensure the proxy certificate is installed as a system certificate. Refer to the section above for how to use environment variables on your platform. - -### How do I use Ollama behind a proxy in Docker? - -The Ollama Docker container image can be configured to use a proxy by passing `-e HTTPS_PROXY=https://proxy.example.com` when starting the container. - -Alternatively, the Docker daemon can be configured to use a proxy. Instructions are available for Docker Desktop on [macOS](https://docs.docker.com/desktop/settings/mac/#proxies), [Windows](https://docs.docker.com/desktop/settings/windows/#proxies), and [Linux](https://docs.docker.com/desktop/settings/linux/#proxies), and Docker [daemon with systemd](https://docs.docker.com/config/daemon/systemd/#httphttps-proxy). - -Ensure the certificate is installed as a system certificate when using HTTPS. This may require a new Docker image when using a self-signed certificate. - -```dockerfile -FROM ollama/ollama -COPY my-ca.pem /usr/local/share/ca-certificates/my-ca.crt -RUN update-ca-certificates -``` - -Build and run this image: - -```shell -docker build -t ollama-with-ca . -docker run -d -e HTTPS_PROXY=https://my.proxy.example.com -p 11434:11434 ollama-with-ca -``` - ## How do I use Ollama with GPU acceleration in Docker? The Ollama Docker container can be configured with GPU acceleration in Linux or Windows (with WSL2). This requires the [nvidia-container-toolkit](https://github.com/NVIDIA/nvidia-container-toolkit). See [ollama/ollama](https://hub.docker.com/r/ollama/ollama) for more details. @@ -197,7 +211,7 @@ Open `Control Panel > Networking and Internet > View network status and tasks` a Click on `Configure` and open the `Advanced` tab. Search through each of the properties until you find `Large Send Offload Version 2 (IPv4)` and `Large Send Offload Version 2 (IPv6)`. *Disable* both of these properties. -## How can I pre-load a model to get faster response times? +## How can I preload a model into Ollama to get faster response times? If you are using the API you can preload a model by sending the Ollama server an empty request. This works with both the `/api/generate` and `/api/chat` API endpoints. @@ -211,6 +225,11 @@ To use the chat completions endpoint, use: curl http://localhost:11434/api/chat -d '{"model": "mistral"}' ``` +To preload a model using the CLI, use the command: +```shell +ollama run llama3 "" +``` + ## How do I keep a model loaded in memory or make it unload immediately? By default models are kept in memory for 5 minutes before being unloaded. This allows for quicker response times if you are making numerous requests to the LLM. You may, however, want to free up the memory before the 5 minutes have elapsed or keep the model loaded indefinitely. Use the `keep_alive` parameter with either the `/api/generate` and `/api/chat` API endpoints to control how long the model is left in memory. @@ -235,8 +254,6 @@ Alternatively, you can change the amount of time all models are loaded into memo If you wish to override the `OLLAMA_KEEP_ALIVE` setting, use the `keep_alive` API parameter with the `/api/generate` or `/api/chat` API endpoints. -## How do I manage the maximum number of requests the server can queue +## How do I manage the maximum number of requests the Ollama server can queue? -If too many requests are sent to the server, it will respond with a 503 error -indicating the server is overloaded. You can adjust how many requests may be -queue by setting `OLLAMA_MAX_QUEUE` +If too many requests are sent to the server, it will respond with a 503 error indicating the server is overloaded. You can adjust how many requests may be queue by setting `OLLAMA_MAX_QUEUE`. diff --git a/docs/troubleshooting.md b/docs/troubleshooting.md index 5971da5f..729ec96c 100644 --- a/docs/troubleshooting.md +++ b/docs/troubleshooting.md @@ -1,104 +1,86 @@ -# How to troubleshoot issues - -Sometimes Ollama may not perform as expected. One of the best ways to figure out what happened is to take a look at the logs. Find the logs on **Mac** by running the command: - -```shell -cat ~/.ollama/logs/server.log -``` - -On **Linux** systems with systemd, the logs can be found with this command: - -```shell -journalctl -u ollama -``` - -When you run Ollama in a **container**, the logs go to stdout/stderr in the container: - -```shell -docker logs -``` -(Use `docker ps` to find the container name) - -If manually running `ollama serve` in a terminal, the logs will be on that terminal. - -When you run Ollama on **Windows**, there are a few different locations. You can view them in the explorer window by hitting `+R` and type in: -- `explorer %LOCALAPPDATA%\Ollama` to view logs -- `explorer %LOCALAPPDATA%\Programs\Ollama` to browse the binaries (The installer adds this to your user PATH) -- `explorer %HOMEPATH%\.ollama` to browse where models and configuration is stored -- `explorer %TEMP%` where temporary executable files are stored in one or more `ollama*` directories - -To enable additional debug logging to help troubleshoot problems, first **Quit the running app from the tray menu** then in a powershell terminal -```powershell -$env:OLLAMA_DEBUG="1" -& "ollama app.exe" -``` - -Join the [Discord](https://discord.gg/ollama) for help interpreting the logs. - -## LLM libraries - -Ollama includes multiple LLM libraries compiled for different GPUs and CPU -vector features. Ollama tries to pick the best one based on the capabilities of -your system. If this autodetection has problems, or you run into other problems -(e.g. crashes in your GPU) you can workaround this by forcing a specific LLM -library. `cpu_avx2` will perform the best, followed by `cpu_avx` an the slowest -but most compatible is `cpu`. Rosetta emulation under MacOS will work with the -`cpu` library. - -In the server log, you will see a message that looks something like this (varies -from release to release): - -``` -Dynamic LLM libraries [rocm_v6 cpu cpu_avx cpu_avx2 cuda_v11 rocm_v5] -``` - -**Experimental LLM Library Override** - -You can set OLLAMA_LLM_LIBRARY to any of the available LLM libraries to bypass -autodetection, so for example, if you have a CUDA card, but want to force the -CPU LLM library with AVX2 vector support, use: - -``` -OLLAMA_LLM_LIBRARY="cpu_avx2" ollama serve -``` - -You can see what features your CPU has with the following. -``` -cat /proc/cpuinfo| grep flags | head -1 -``` - -## Installing older or pre-release versions on Linux - -If you run into problems on Linux and want to install an older version, or you'd -like to try out a pre-release before it's officially released, you can tell the -install script which version to install. - -```sh -curl -fsSL https://ollama.com/install.sh | OLLAMA_VERSION="0.1.29" sh -``` - -## Linux tmp noexec - -If your system is configured with the "noexec" flag where Ollama stores its -temporary executable files, you can specify an alternate location by setting -OLLAMA_TMPDIR to a location writable by the user ollama runs as. For example -OLLAMA_TMPDIR=/usr/share/ollama/ - -## Container fails to run on NVIDIA GPU - -Make sure you've set up the container runtime first as described in [docker.md](./docker.md) - -Sometimes the container runtime can have difficulties initializing the GPU. -When you check the server logs, this can show up as various error codes, such -as "3" (not initialized), "46" (device unavailable), "100" (no device), "999" -(unknown), or others. The following troubleshooting techniques may help resolve -the problem - -- Is the uvm driver not loaded? `sudo nvidia-modprobe -u` -- Try reloading the nvidia_uvm driver - `sudo rmmod nvidia_uvm` then `sudo modprobe nvidia_uvm` -- Try rebooting -- Make sure you're running the latest nvidia drivers - -If none of those resolve the problem, gather additional information and file an issue: -- Set `CUDA_ERROR_LEVEL=50` and try again to get more diagnostic logs -- Check dmesg for any errors `sudo dmesg | grep -i nvrm` and `sudo dmesg | grep -i nvidia` +# How to troubleshoot issues + +Sometimes Ollama may not perform as expected. One of the best ways to figure out what happened is to take a look at the logs. Find the logs on **Mac** by running the command: + +```shell +cat ~/.ollama/logs/server.log +``` + +On **Linux** systems with systemd, the logs can be found with this command: + +```shell +journalctl -u ollama +``` + +When you run Ollama in a **container**, the logs go to stdout/stderr in the container: + +```shell +docker logs +``` +(Use `docker ps` to find the container name) + +If manually running `ollama serve` in a terminal, the logs will be on that terminal. + +When you run Ollama on **Windows**, there are a few different locations. You can view them in the explorer window by hitting `+R` and type in: +- `explorer %LOCALAPPDATA%\Ollama` to view logs +- `explorer %LOCALAPPDATA%\Programs\Ollama` to browse the binaries (The installer adds this to your user PATH) +- `explorer %HOMEPATH%\.ollama` to browse where models and configuration is stored +- `explorer %TEMP%` where temporary executable files are stored in one or more `ollama*` directories + +To enable additional debug logging to help troubleshoot problems, first **Quit the running app from the tray menu** then in a powershell terminal +```powershell +$env:OLLAMA_DEBUG="1" +& "ollama app.exe" +``` + +Join the [Discord](https://discord.gg/ollama) for help interpreting the logs. + +## LLM libraries + +Ollama includes multiple LLM libraries compiled for different GPUs and CPU vector features. Ollama tries to pick the best one based on the capabilities of your system. If this autodetection has problems, or you run into other problems (e.g. crashes in your GPU) you can workaround this by forcing a specific LLM library. `cpu_avx2` will perform the best, followed by `cpu_avx` an the slowest but most compatible is `cpu`. Rosetta emulation under MacOS will work with the `cpu` library. + +In the server log, you will see a message that looks something like this (varies from release to release): + +``` +Dynamic LLM libraries [rocm_v6 cpu cpu_avx cpu_avx2 cuda_v11 rocm_v5] +``` + +**Experimental LLM Library Override** + +You can set OLLAMA_LLM_LIBRARY to any of the available LLM libraries to bypass autodetection, so for example, if you have a CUDA card, but want to force the CPU LLM library with AVX2 vector support, use: + +``` +OLLAMA_LLM_LIBRARY="cpu_avx2" ollama serve +``` + +You can see what features your CPU has with the following. +``` +cat /proc/cpuinfo| grep flags | head -1 +``` + +## Installing older or pre-release versions on Linux + +If you run into problems on Linux and want to install an older version, or you'd like to try out a pre-release before it's officially released, you can tell the install script which version to install. + +```sh +curl -fsSL https://ollama.com/install.sh | OLLAMA_VERSION="0.1.29" sh +``` + +## Linux tmp noexec + +If your system is configured with the "noexec" flag where Ollama stores its temporary executable files, you can specify an alternate location by setting OLLAMA_TMPDIR to a location writable by the user ollama runs as. For example OLLAMA_TMPDIR=/usr/share/ollama/ + +## Container fails to run on NVIDIA GPU + +Make sure you've set up the container runtime first as described in [docker.md](./docker.md) + +Sometimes the container runtime can have difficulties initializing the GPU. When you check the server logs, this can show up as various error codes, such as "3" (not initialized), "46" (device unavailable), "100" (no device), "999" (unknown), or others. The following troubleshooting techniques may help resolve the problem + +- Is the uvm driver not loaded? `sudo nvidia-modprobe -u` +- Try reloading the nvidia_uvm driver - `sudo rmmod nvidia_uvm` then `sudo modprobe nvidia_uvm` +- Try rebooting +- Make sure you're running the latest nvidia drivers + +If none of those resolve the problem, gather additional information and file an issue: +- Set `CUDA_ERROR_LEVEL=50` and try again to get more diagnostic logs +- Check dmesg for any errors `sudo dmesg | grep -i nvrm` and `sudo dmesg | grep -i nvidia`