1
0
mirror of https://github.com/containers/ramalama.git synced 2026-02-05 15:47:26 +01:00
Files
ramalama/docsite/docs/configuration/conf.mdx
Oliver Walsh 58aaea1c00 Bump to v0.16.0
Signed-off-by: Oliver Walsh <owalsh@redhat.com>
2025-12-18 14:19:28 +00:00

267 lines
9.2 KiB
Plaintext

---
title: Configuration File
description: Configuration file reference
# This file is auto-generated from manpages. Do not edit manually.
# Source: ramalama.conf.5.md
---
# Configuration File
# DESCRIPTION
RamaLama reads all ramalama.conf files, if they exists
and modify the defaults for running RamaLama on the host. ramalama.conf uses
a TOML format that can be easily modified and versioned.
RamaLama reads the he following paths for global configuration that effects all users.
| Paths | Exception |
| ----------------------------------- | ----------------------------------- |
| __/usr/share/ramalama/ramalama.conf__ | On Linux |
| __/usr/local/share/ramalama/ramalama.conf__ | On Linux |
| __/etc/ramalama/ramalama.conf__ | On Linux |
| __/etc/ramalama/ramalama.conf.d/\*.conf__ | On Linux |
| __$HOME/.local/.pipx/venvs/usr/share/ramalama/ramalama.conf__ |On pipx installed macOS |
For user specific configuration it reads
| Paths | Exception |
| ----------------------------------- | ------------------------------ |
| __$XDG_CONFIG_HOME/ramalama/ramalama.conf__ | |
| __$XDG_CONFIG_HOME/ramalama/ramalama.conf.d/\*.conf__ | |
| __$HOME/.config/ramalama/ramalama.conf__ | `$XDG_CONFIG_HOME` not set |
| __$HOME/.config/ramalama/ramalama.conf.d/\*.conf__ | `$XDG_CONFIG_HOME` not set |
Fields specified in ramalama conf files override the default options, as well as
options in previously read ramalama conf files.
Config files in the `.d` directories, are added in alpha numeric sorted order and must end in `.conf`.
## ENVIRONMENT VARIABLES
If the `RAMALAMA_CONFIG` environment variable is set, all system and user
config files are ignored and only the specified config file is loaded.
# FORMAT
The [TOML format][toml] is used as the encoding of the configuration file.
Every option is nested under its table. No bare options are used. The format of
TOML can be simplified to:
[table1]
option = value
[table2]
option = value
[table3]
option = value
[table3.subtable1]
option = value
## RAMALAMA TABLE
The ramalama table contains settings to configure and manage the OCI runtime.
`[[ramalama]]`
**api**="none"
Unified API layer for Inference, RAG, Agents, Tools, Safety, Evals, and Telemetry.
Options: llama-stack, none
**api_key**=""
OpenAI-compatible API key. Can also be set via the RAMALAMA_API_KEY environment variable.
**carimage**="registry.access.redhat.com/ubi10-micro:latest"
OCI model car image
Image to be used when building and pushing --type=car models
**cache_reuse**=256
Min chunk size to attempt reusing from the cache via KV shifting
**container**=true
Run RamaLama in the default container.
RAMALAMA_IN_CONTAINER environment variable overrides this field.
**convert_type**="raw"
Convert the MODEL to the specified OCI Object
Options: artifact, car, raw
| Type | Description |
| -------- | ------------------------------------------------------------- |
| artifact | Store AI Models as artifacts |
| car | Traditional OCI image including base image with the model stored in a /models subdir |
| raw | Traditional OCI image including only the model and a link file `model.file` pointed at it stored at / |
**ctx_size**=0
Size of the prompt context (0 = loaded from model)
**engine**="podman"
Run RamaLama using the specified container engine.
Valid options are: Podman and Docker
This field can be overridden by the RAMALAMA_CONTAINER_ENGINE environment variable.
**env**=[]
Environment variables to be added to the environment used when running in a container engine (e.g., Podman, Docker). For example "LLAMA_ARG_THREADS=10".
**gguf_quantization_mode**="Q4_K_M"
The quantization mode used when creating OCI formatted AI Models.
Available options: Q2_K, Q3_K_S, Q3_K_M, Q3_K_L, Q4_0, Q4_K_S, Q4_K_M, Q5_0, Q5_K_S, Q5_K_M, Q6_K, Q8_0.
**host**="0.0.0.0"
IP address for llama.cpp to listen on.
**image**="quay.io/ramalama/ramalama:latest"
OCI container image to run with the specified AI model
RAMALAMA_IMAGE environment variable overrides this field.
`[[ramalama.images]]`
HIP_VISIBLE_DEVICES = "quay.io/ramalama/rocm"
CUDA_VISIBLE_DEVICES = "quay.io/ramalama/cuda"
ASAHI_VISIBLE_DEVICES = "quay.io/ramalama/asahi"
INTEL_VISIBLE_DEVICES = "quay.io/ramalama/intel-gpu"
ASCEND_VISIBLE_DEVICES = "quay.io/ramalama/cann"
MUSA_VISIBLE_DEVICES = "quay.io/ramalama/musa"
VLLM = "registry.redhat.io/rhelai1/ramalama-vllm"
Alternative images to use when RamaLama recognizes specific hardware or user
specified vllm model runtime.
**keep_groups**=false
Pass `--group-add keep-groups` to podman, when using podman.
In some cases this is needed to access the gpu from a rootless container
**log_level**=warning
Set the logging level of RamaLama application.
Valid Values:
debug, info, warning, error, critical
:::note
--debug option overrides this field and forces the system to debug
:::
**max_tokens**=0
Maximum number of tokens to generate. Set to 0 for unlimited output (default: 0).
This parameter is mapped to the appropriate runtime-specific parameter when executing models.
**ngl**=-1
number of gpu layers, 0 means CPU inferencing, 999 means use max layers (default: -1)
The default -1, means use whatever is automatically deemed appropriate (0 or 999)
**prefix**=""
Specify default prefix for chat and run command. By default the prefix
is based on the container engine used.
| Container Engine| Prefix |
| --------------- | ------- |
| Podman | "🦭 > " |
| Docker | "🐋 > " |
| No Engine | "🦙 > " |
| No EMOJI support| "> " |
**port**="8080"
Specify initial port for a range of 101 ports for services to listen on.
If this port is unavailable, another free port from this range will be selected.
**pull**="newer"
- **always**: Always pull the image and throw an error if the pull fails.
- **missing**: Only pull the image when it does not exist in the local containers storage. Throw an error if no image is found and the pull fails.
- **never**: Never pull the image but use the one from the local containers storage. Throw an error when no image is found.
- **newer**: Pull if the image on the registry is newer than the one in the local containers storage. An image is considered to be newer when the digests are different. Comparing the time stamps is prone to errors. Pull errors are suppressed if a local image was found.
**rag_format**="qdrant"
Specify the default output format for output of the `ramalama rag` command.
Options: qdrant, json, markdown, milvus.
**rag_images**="quay.io/ramalama/ramalama-rag"
OCI container image to run with the specified AI model when using RAG content.
`[[ramalama.rag_images]]`
CUDA_VISIBLE_DEVICES = "quay.io/ramalama/cuda-rag"
HIP_VISIBLE_DEVICES = "quay.io/ramalama/rocm-rag"
INTEL_VISIBLE_DEVICES = "quay.io/ramalama/intel-gpu-rag"
GGML_VK_VISIBLE_DEVICES = "quay.io/ramalama/ramalama"
**runtime**="llama.cpp"
Specify the AI runtime to use; valid options are 'llama.cpp', 'vllm', and 'mlx' (default: llama.cpp)
Options: llama.cpp, vllm, mlx
**selinux**=false
SELinux container separation enforcement
**store**="$HOME/.local/share/ramalama"
Store AI Models in the specified directory
**summarize_after**=4
Automatically summarize conversation history after N messages to prevent context growth.
When enabled, ramalama will periodically condense older messages into a summary,
keeping only recent messages and the summary. This prevents the context from growing
indefinitely during long chat sessions. Set to 0 to disable (default: 4).
**temp**="0.8"
Temperature of the response from the AI Model
llama.cpp explains this as:
The lower the number is, the more deterministic the response.
The higher the number is the more creative the response is, but more likely to hallucinate when set too high.
Usage: Lower numbers are good for virtual assistants where we need deterministic responses. Higher numbers are good for roleplay or creative tasks like editing stories
**thinking**=true
Enable thinking mode on reasoning models
**threads**=-1
maximum number of cpu threads to use for inferencing
The default -1, uses the default of the underlying implementation
**transport**="ollama"
Specify the default transport to be used for pulling and pushing of AI Models.
Options: oci, ollama, huggingface.
RAMALAMA_TRANSPORT environment variable overrides this field.
`[[ramalama.http_client]]`
Http client configuration
**max_retries**=5
The maximum number of times to retry a failed download
**max_retry_delay**=30
The maximum delay between retry attempts in seconds
## RAMALAMA.USER TABLE
The ramalama.user table contains user preference settings.
`[[ramalama.user]]`
**no_missing_gpu_prompt**=false
Suppress the interactive prompt when running on macOS with a Podman VM that does not support GPU acceleration (e.g., applehv provider). When set to true, RamaLama will automatically proceed without GPU support instead of prompting the user for confirmation. This is useful for automation and scripting scenarios where interactive prompts are not desired.
Can also be set via the RAMALAMA_USER__NO_MISSING_GPU_PROMPT environment variable.