
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
</a>
<a href="[***]" target="_blank">
</a>
<a href="https://hub.docker.com/r/infiniflow/ragflow" target="_blank">
</a>
<a href="https://github.com/infiniflow/ragflow/releases/latest">
</a>
<a href="https://github.com/infiniflow/ragflow/blob/main/LICENSE">
</a>
<a href="[***]">
</a>
Cloud | Document | https://github.com/infiniflow/ragflow/issues/*** | ***
RAGFlow is a leading open-source Retrieval-Augmented Generation (RAG) engine that fuses cutting-edge RAG with Agent capabilities to create a superior context layer for LLMs. It offers a streamlined RAG workflow adaptable to enterprises of any scale. Powered by a converged context engine and pre-built agent templates, RAGFlow enables developers to transform complex data into high-fidelity, production-ready AI systems with exceptional efficiency and precision.
Try our cloud service at [***]
⭐️ Star our repository to stay up-to-date with exciting new features and improvements! Get instant notifications for new releases! 🌟
[!TIP] If you have not installed Docker on your local machine (Windows, Mac, or Linux), see https://docs.docker.com/engine/install/.
Ensure vm.max_map_count >= 262144:
To check the value of
vm.max_map_count:bash$ sysctl vm.max_map_countReset
vm.max_map_countto a value at least 262144 if it is not.bash# In this case, we set it to 262144: $ sudo sysctl -w vm.max_map_count=262144This change will be reset after a system reboot. To ensure your change remains permanent, add or update the
vm.max_map_countvalue in /etc/sysctl.conf accordingly:bashvm.max_map_count=262144
Clone the repo:
bash$ git clone https://github.com/infiniflow/ragflow.git
Start up the server using the pre-built Docker images:
[!CAUTION] All Docker images are built for x86 platforms. We don't currently offer Docker images for ARM64. If you are on an ARM64 platform, follow this guide to build a Docker image compatible with your system.
The command below downloads the
v0.25.6edition of the RAGFlow Docker image. See the following table for descriptions of different RAGFlow editions. To download a RAGFlow edition different fromv0.25.6, update theRAGFLOW_IMAGEvariable accordingly in docker/.env before usingdocker composeto start the server.
bash$ cd ragflow/docker # git checkout v0.25.6 # Optional: use a stable tag (see releases: https://github.com/infiniflow/ragflow/releases) # This step ensures the **entrypoint.sh** file in the code matches the Docker image version. # Use CPU for DeepDoc tasks: $ docker compose -f docker-compose.yml up -d # To use GPU to accelerate DeepDoc tasks: # sed -i '1i DEVICE=gpu' .env # docker compose -f docker-compose.yml up -d
Note: Prior to
v0.22.0, we provided both images with embedding models and slim images without embedding models. Details as follows:
| RAGFlow image tag | Image size (GB) | Has embedding models? | Stable? |
|---|---|---|---|
| v0.21.1 | ≈9 | ✔️ | Stable release |
| v0.21.1-slim | ≈2 | ❌ | Stable release |
Starting with
v0.22.0, we ship only the slim edition and no longer append the -slim suffix to the image tag.
Check the server status after having the server up and running:
bash$ docker logs -f docker-ragflow-cpu-1
The following output confirms a successful launch of the system:
bash____ ___ ______ ______ __ / __ \ / | / ____// ____// /____ _ __ / /_/ // /| | / / __ / /_ / // __ \| | /| / / / _, _// ___ |/ /_/ // __/ / // /_/ /| |/ |/ / /_/ |_|/_/ |_|\____//_/ /_/ \____/ |__/|__/ * Running on all addresses (0.0.0.0)
If you skip this confirmation step and directly log in to RAGFlow, your browser may pro*** a
network abnormalerror because, at that moment, your RAGFlow may not be fully initialized.
In your web browser, enter the IP address of your server and log in to RAGFlow.
With the default settings, you only need to enter
http://IP_OF_YOUR_MACHINE(sans port number) as the default HTTP serving port80can be omitted when using the default configurations.
In service_conf.yaml.template, select the desired LLM factory in user_default_llm and update
the API_KEY field with the corresponding API key.
See llm_api_key_setup for more information.
The show is on!
When it comes to system configurations, you will need to manage the following files:
SVR_HTTP_PORT, MYSQL_PASSWORD, and
MINIO_PASSWORD.The ./docker/README file provides a detailed description of the environment settings and service configurations which can be used as
${ENV_VARS}in the service_conf.yaml.template file.
To update the default HTTP serving port (80), go to docker-compose.yml and change 80:80
to <YOUR_SERVING_PORT>:80.
Updates to the above configurations require a reboot of all containers to take effect:
bash$ docker compose -f docker-compose.yml up -d
RAGFlow uses Elasticsearch by default for storing full text and vectors. To switch to https://github.com/infiniflow/infinity/, follow these steps:
Stop all running containers:
bash$ docker compose -f docker/docker-compose.yml down -v
[!WARNING]
-vwill delete the docker container volumes, and the existing data will be cleared.
Set DOC_ENGINE in docker/.env to infinity.
Start the containers:
bash$ docker compose -f docker-compose.yml up -d
[!WARNING] Switching to Infinity on a Linux/arm64 machine is not yet officially supported.
This image is approximately 2 GB in size and relies on external LLM and embedding services.
bashgit clone https://github.com/infiniflow/ragflow.git cd ragflow/ docker build --platform linux/amd64 -f Dockerfile -t infiniflow/ragflow:nightly .
Or if you are behind a proxy, you can pass proxy arguments:
bashdocker build --platform linux/amd64 \ --build-arg http_proxy=http://YOUR_PROXY:PORT \ --build-arg https_proxy=http://YOUR_PROXY:PORT \ -f Dockerfile -t infiniflow/ragflow:nightly .
Install uv and pre-commit, or skip this step if they are already installed:
bashpipx install uv pre-commit
Clone the source code and install Python dependencies:
bashgit clone https://github.com/infiniflow/ragflow.git cd ragflow/ uv sync --python 3.13 # install RAGFlow dependent python modules uv run python3 download_deps.py pre-commit install
Launch the dependent services (MinIO, Elasticsearch, Redis, and MySQL) using Docker Compose:
bashdocker compose -f docker/docker-compose-base.yml up -d
Add the following line to /etc/hosts to resolve all hosts specified in docker/.env to 127.0.0.1:
127.0.0.1 es01 infinity mysql minio redis sandbox-executor-manager
If you cannot access HuggingFace, set the HF_ENDPOINT environment variable to use a mirror site:
bashexport HF_ENDPOINT=https://hf-mirror.com
If your operating system does not have jemalloc, please install it as follows:
bash# Ubuntu sudo apt-get install libjemalloc-dev # CentOS sudo yum install jemalloc # OpenSUSE sudo zypper install jemalloc # macOS sudo brew install jemalloc
Launch backend service:
bashsource .venv/bin/activate export PYTHONPATH=$(pwd) bash docker/launch_backend_service.sh
Install frontend dependencies:
bashcd web npm install
Launch frontend service:
bashnpm run dev
The following output confirms a successful launch of the system:
Stop RAGFlow front-end and back-end service after development is complete:
bashpkill -f "ragflow_server.py|task_executor.py"
See the https://github.com/infiniflow/ragflow/issues/***
RAGFlow flourishes via open-source collaboration. In this spirit, we embrace diverse contributions from the community. If you would like to be a part, review our Contribution Guidelines first.
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务
以下是 infiniflow/ragflow 相关的常用 Docker 镜像,适用于 不同场景 等不同场景: