Back to Ragflow

Launch service from source

docs/develop/launch_ragflow_from_source.md

0.25.13.7 KB
Original Source

Launch service from source

A guide explaining how to set up a RAGFlow service from its source code. By following this guide, you'll be able to debug using the source code.

Target audience

Developers who have added new features or modified existing code and wish to debug using the source code, provided that their machine has the target deployment environment set up.

Prerequisites

  • CPU ≥ 4 cores
  • RAM ≥ 16 GB
  • Disk ≥ 50 GB
  • Docker ≥ 24.0.0 & Docker Compose ≥ v2.26.1

:::tip NOTE If you have not installed Docker on your local machine (Windows, Mac, or Linux), see the Install Docker Engine guide. :::

Launch a service from source

To launch a RAGFlow service from source code:

Clone the RAGFlow repository

bash
git clone https://github.com/infiniflow/ragflow.git
cd ragflow/

Install Python dependencies

  1. Install uv:

    bash
    pipx install uv
    
  2. Install RAGFlow service's Python dependencies:

    bash
    uv sync --python 3.12 --frozen
    

    A virtual environment named .venv is created, and all Python dependencies are installed into the new environment.

    If you need to run tests against the RAGFlow service, install the test dependencies:

    bash
    uv sync --python 3.12 --group test --frozen && uv pip install sdk/python --group test
    

Launch third-party services

The following command launches the 'base' services (MinIO, Elasticsearch, Redis, and MySQL) using Docker Compose:

bash
docker compose -f docker/docker-compose-base.yml up -d

Update host and port Settings for Third-party Services

  1. Add the following line to /etc/hosts to resolve all hosts specified in docker/service_conf.yaml.template to 127.0.0.1:

    127.0.0.1       es01 infinity mysql minio redis
    
  2. In docker/service_conf.yaml.template, update mysql port to 5455 and es port to 1200, as specified in docker/.env.

Launch the RAGFlow backend service

  1. Comment out the nginx line in docker/entrypoint.sh.

    # /usr/sbin/nginx
    
  2. Activate the Python virtual environment:

    bash
    source .venv/bin/activate
    export PYTHONPATH=$(pwd)
    
  3. Optional: If you cannot access HuggingFace, set the HF_ENDPOINT environment variable to use a mirror site:

    bash
    export HF_ENDPOINT=https://hf-mirror.com
    
  4. Check the configuration in conf/service_conf.yaml, ensuring all hosts and ports are correctly set.

  5. Run the entrypoint.sh script to launch the backend service:

    shell
    JEMALLOC_PATH=$(pkg-config --variable=libdir jemalloc)/libjemalloc.so;
    LD_PRELOAD=$JEMALLOC_PATH python rag/svr/task_executor.py 1;
    
    shell
    python api/ragflow_server.py;
    

Launch the RAGFlow frontend service

  1. Navigate to the web directory and install the frontend dependencies:

    bash
    cd web
    npm install
    
  2. Update server.proxy.target in vite.config.ts to http://127.0.0.1:9380:

    bash
    vim vite.config.ts
    
  3. Start up the RAGFlow frontend service:

    bash
    npm run dev 
    

    The following message appears, showing the IP address and port number of your frontend service:

Access the RAGFlow service

In your web browser, enter http://127.0.0.1:<PORT>/, ensuring the port number matches that shown in the screenshot above.

Stop the RAGFlow service when the development is done

  1. Stop the RAGFlow frontend service:

    bash
    pkill npm
    
  2. Stop the RAGFlow backend service:

    bash
    pkill -f "docker/entrypoint.sh"