mirror of
https://git.mirrors.martin98.com/https://github.com/infiniflow/ragflow.git
synced 2025-06-04 11:24:00 +08:00
Improved image build instructions (#3580)
### What problem does this PR solve? Improved arm64 image build instructions ### Type of change - [x] Documentation Update - [x] Refactoring
This commit is contained in:
parent
8872aed512
commit
646ac1f2b4
8
.github/workflows/tests.yml
vendored
8
.github/workflows/tests.yml
vendored
@ -48,13 +48,13 @@ jobs:
|
|||||||
- name: Build ragflow:dev-slim
|
- name: Build ragflow:dev-slim
|
||||||
run: |
|
run: |
|
||||||
RUNNER_WORKSPACE_PREFIX=${RUNNER_WORKSPACE_PREFIX:-$HOME}
|
RUNNER_WORKSPACE_PREFIX=${RUNNER_WORKSPACE_PREFIX:-$HOME}
|
||||||
cp -r ${RUNNER_WORKSPACE_PREFIX}/huggingface.co ${RUNNER_WORKSPACE_PREFIX}/nltk_data ${RUNNER_WORKSPACE_PREFIX}/libssl*.deb ${RUNNER_WORKSPACE_PREFIX}/tika-server*.jar* .
|
cp -r ${RUNNER_WORKSPACE_PREFIX}/huggingface.co ${RUNNER_WORKSPACE_PREFIX}/nltk_data ${RUNNER_WORKSPACE_PREFIX}/libssl*.deb ${RUNNER_WORKSPACE_PREFIX}/tika-server*.jar* ${RUNNER_WORKSPACE_PREFIX}/chrome* ${RUNNER_WORKSPACE_PREFIX}/cl100k_base.tiktoken .
|
||||||
sudo docker pull ubuntu:24.04
|
sudo docker pull ubuntu:22.04
|
||||||
sudo ./build_docker_image.sh slim
|
sudo docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
|
|
||||||
- name: Build ragflow:dev
|
- name: Build ragflow:dev
|
||||||
run: |
|
run: |
|
||||||
sudo ./build_docker_image.sh full
|
sudo docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
|
|
||||||
- name: Start ragflow:dev-slim
|
- name: Start ragflow:dev-slim
|
||||||
run: |
|
run: |
|
||||||
|
35
Dockerfile
35
Dockerfile
@ -1,8 +1,8 @@
|
|||||||
# base stage
|
# base stage
|
||||||
FROM ubuntu:22.04 AS base
|
FROM ubuntu:22.04 AS base
|
||||||
USER root
|
USER root
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
ARG ARCH=amd64
|
|
||||||
ENV LIGHTEN=0
|
ENV LIGHTEN=0
|
||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
@ -18,7 +18,7 @@ RUN sed -i 's|http://archive.ubuntu.com|https://mirrors.tuna.tsinghua.edu.cn|g'
|
|||||||
|
|
||||||
RUN --mount=type=cache,id=ragflow_base_apt,target=/var/cache/apt,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_base_apt,target=/var/cache/apt,sharing=locked \
|
||||||
apt update && DEBIAN_FRONTEND=noninteractive apt install -y curl libpython3-dev nginx libglib2.0-0 libglx-mesa0 pkg-config libicu-dev libgdiplus default-jdk python3-pip pipx \
|
apt update && DEBIAN_FRONTEND=noninteractive apt install -y curl libpython3-dev nginx libglib2.0-0 libglx-mesa0 pkg-config libicu-dev libgdiplus default-jdk python3-pip pipx \
|
||||||
libatk-bridge2.0-0 libgtk-4-1 libnss3 xdg-utils unzip libgbm-dev wget \
|
libatk-bridge2.0-0 libgtk-4-1 libnss3 xdg-utils unzip libgbm-dev wget git \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple && pip3 config set global.trusted-host "pypi.tuna.tsinghua.edu.cn mirrors.pku.edu.cn" && pip3 config set global.extra-index-url "https://mirrors.pku.edu.cn/pypi/web/simple" \
|
RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple && pip3 config set global.trusted-host "pypi.tuna.tsinghua.edu.cn mirrors.pku.edu.cn" && pip3 config set global.extra-index-url "https://mirrors.pku.edu.cn/pypi/web/simple" \
|
||||||
@ -28,8 +28,11 @@ RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple &&
|
|||||||
# https://forum.aspose.com/t/aspose-slides-for-net-no-usable-version-of-libssl-found-with-linux-server/271344/13
|
# https://forum.aspose.com/t/aspose-slides-for-net-no-usable-version-of-libssl-found-with-linux-server/271344/13
|
||||||
# aspose-slides on linux/arm64 is unavailable
|
# aspose-slides on linux/arm64 is unavailable
|
||||||
RUN --mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_amd64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb \
|
RUN --mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_amd64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb \
|
||||||
if [ "${ARCH}" = "amd64" ]; then \
|
--mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_arm64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_arm64.deb \
|
||||||
|
if [ "$(uname -m)" = "x86_64" ]; then \
|
||||||
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb; \
|
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb; \
|
||||||
|
elif [ "$(uname -m)" = "aarch64" ]; then \
|
||||||
|
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_arm64.deb; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 DOTNET_SYSTEM_GLOBALIZATION_INVARIANT=1
|
ENV PYTHONDONTWRITEBYTECODE=1 DOTNET_SYSTEM_GLOBALIZATION_INVARIANT=1
|
||||||
@ -56,6 +59,24 @@ USER root
|
|||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
|
|
||||||
|
COPY .git /ragflow/.git
|
||||||
|
|
||||||
|
RUN current_commit=$(git rev-parse --short HEAD); \
|
||||||
|
last_tag=$(git describe --tags --abbrev=0); \
|
||||||
|
commit_count=$(git rev-list --count "$last_tag..HEAD"); \
|
||||||
|
version_info=""; \
|
||||||
|
if [ "$commit_count" -eq 0 ]; then \
|
||||||
|
version_info=$last_tag; \
|
||||||
|
else \
|
||||||
|
version_info="$current_commit($last_tag~$commit_count)"; \
|
||||||
|
fi; \
|
||||||
|
if [ "$LIGHTEN" == "1" ]; then \
|
||||||
|
version_info="$version_info slim"; \
|
||||||
|
else \
|
||||||
|
version_info="$version_info full"; \
|
||||||
|
fi; \
|
||||||
|
echo $version_info > /ragflow/VERSION
|
||||||
|
|
||||||
COPY web web
|
COPY web web
|
||||||
COPY docs docs
|
COPY docs docs
|
||||||
RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
||||||
@ -65,10 +86,10 @@ RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
|||||||
COPY pyproject.toml poetry.toml poetry.lock ./
|
COPY pyproject.toml poetry.toml poetry.lock ./
|
||||||
|
|
||||||
RUN --mount=type=cache,id=ragflow_builder_poetry,target=/root/.cache/pypoetry,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_builder_poetry,target=/root/.cache/pypoetry,sharing=locked \
|
||||||
if [ "$LIGHTEN" -eq 0 ]; then \
|
if [ "$LIGHTEN" == "1" ]; then \
|
||||||
poetry install --no-root --with=full; \
|
|
||||||
else \
|
|
||||||
poetry install --no-root; \
|
poetry install --no-root; \
|
||||||
|
else \
|
||||||
|
poetry install --no-root --with=full; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# production stage
|
# production stage
|
||||||
@ -77,6 +98,8 @@ USER root
|
|||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
|
|
||||||
|
COPY --from=builder /ragflow/VERSION /ragflow/VERSION
|
||||||
|
|
||||||
# Install python packages' dependencies
|
# Install python packages' dependencies
|
||||||
# cv2 requires libGL.so.1
|
# cv2 requires libGL.so.1
|
||||||
RUN --mount=type=cache,id=ragflow_production_apt,target=/var/cache/apt,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_production_apt,target=/var/cache/apt,sharing=locked \
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
# base stage
|
# base stage
|
||||||
FROM ubuntu:22.04 AS base
|
FROM ubuntu:22.04 AS base
|
||||||
USER root
|
USER root
|
||||||
|
SHELL ["/bin/bash", "-c"]
|
||||||
|
|
||||||
ARG ARCH=amd64
|
|
||||||
ENV LIGHTEN=1
|
ENV LIGHTEN=1
|
||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
@ -18,7 +18,7 @@ RUN sed -i 's|http://archive.ubuntu.com|https://mirrors.tuna.tsinghua.edu.cn|g'
|
|||||||
|
|
||||||
RUN --mount=type=cache,id=ragflow_base_apt,target=/var/cache/apt,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_base_apt,target=/var/cache/apt,sharing=locked \
|
||||||
apt update && DEBIAN_FRONTEND=noninteractive apt install -y curl libpython3-dev nginx libglib2.0-0 libglx-mesa0 pkg-config libicu-dev libgdiplus default-jdk python3-pip pipx \
|
apt update && DEBIAN_FRONTEND=noninteractive apt install -y curl libpython3-dev nginx libglib2.0-0 libglx-mesa0 pkg-config libicu-dev libgdiplus default-jdk python3-pip pipx \
|
||||||
libatk-bridge2.0-0 libgtk-4-1 libnss3 xdg-utils unzip libgbm-dev wget \
|
libatk-bridge2.0-0 libgtk-4-1 libnss3 xdg-utils unzip libgbm-dev wget git \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple && pip3 config set global.trusted-host "pypi.tuna.tsinghua.edu.cn mirrors.pku.edu.cn" && pip3 config set global.extra-index-url "https://mirrors.pku.edu.cn/pypi/web/simple" \
|
RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple && pip3 config set global.trusted-host "pypi.tuna.tsinghua.edu.cn mirrors.pku.edu.cn" && pip3 config set global.extra-index-url "https://mirrors.pku.edu.cn/pypi/web/simple" \
|
||||||
@ -28,8 +28,11 @@ RUN pip3 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple &&
|
|||||||
# https://forum.aspose.com/t/aspose-slides-for-net-no-usable-version-of-libssl-found-with-linux-server/271344/13
|
# https://forum.aspose.com/t/aspose-slides-for-net-no-usable-version-of-libssl-found-with-linux-server/271344/13
|
||||||
# aspose-slides on linux/arm64 is unavailable
|
# aspose-slides on linux/arm64 is unavailable
|
||||||
RUN --mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_amd64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb \
|
RUN --mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_amd64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb \
|
||||||
if [ "${ARCH}" = "amd64" ]; then \
|
--mount=type=bind,source=libssl1.1_1.1.1f-1ubuntu2_arm64.deb,target=/root/libssl1.1_1.1.1f-1ubuntu2_arm64.deb \
|
||||||
|
if [ "$(uname -m)" = "x86_64" ]; then \
|
||||||
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb; \
|
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_amd64.deb; \
|
||||||
|
elif [ "$(uname -m)" = "aarch64" ]; then \
|
||||||
|
dpkg -i /root/libssl1.1_1.1.1f-1ubuntu2_arm64.deb; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 DOTNET_SYSTEM_GLOBALIZATION_INVARIANT=1
|
ENV PYTHONDONTWRITEBYTECODE=1 DOTNET_SYSTEM_GLOBALIZATION_INVARIANT=1
|
||||||
@ -56,6 +59,24 @@ USER root
|
|||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
|
|
||||||
|
COPY .git /ragflow/.git
|
||||||
|
|
||||||
|
RUN current_commit=$(git rev-parse --short HEAD); \
|
||||||
|
last_tag=$(git describe --tags --abbrev=0); \
|
||||||
|
commit_count=$(git rev-list --count "$last_tag..HEAD"); \
|
||||||
|
version_info=""; \
|
||||||
|
if [ "$commit_count" -eq 0 ]; then \
|
||||||
|
version_info=$last_tag; \
|
||||||
|
else \
|
||||||
|
version_info="$current_commit($last_tag~$commit_count)"; \
|
||||||
|
fi; \
|
||||||
|
if [ "$LIGHTEN" == "1" ]; then \
|
||||||
|
version_info="$version_info slim"; \
|
||||||
|
else \
|
||||||
|
version_info="$version_info full"; \
|
||||||
|
fi; \
|
||||||
|
echo $version_info > /ragflow/VERSION
|
||||||
|
|
||||||
COPY web web
|
COPY web web
|
||||||
COPY docs docs
|
COPY docs docs
|
||||||
RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
||||||
@ -65,10 +86,10 @@ RUN --mount=type=cache,id=ragflow_builder_npm,target=/root/.npm,sharing=locked \
|
|||||||
COPY pyproject.toml poetry.toml poetry.lock ./
|
COPY pyproject.toml poetry.toml poetry.lock ./
|
||||||
|
|
||||||
RUN --mount=type=cache,id=ragflow_builder_poetry,target=/root/.cache/pypoetry,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_builder_poetry,target=/root/.cache/pypoetry,sharing=locked \
|
||||||
if [ "$LIGHTEN" -eq 0 ]; then \
|
if [ "$LIGHTEN" == "1" ]; then \
|
||||||
poetry install --no-root --with=full; \
|
|
||||||
else \
|
|
||||||
poetry install --no-root; \
|
poetry install --no-root; \
|
||||||
|
else \
|
||||||
|
poetry install --no-root --with=full; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# production stage
|
# production stage
|
||||||
@ -77,6 +98,8 @@ USER root
|
|||||||
|
|
||||||
WORKDIR /ragflow
|
WORKDIR /ragflow
|
||||||
|
|
||||||
|
COPY --from=builder /ragflow/VERSION /ragflow/VERSION
|
||||||
|
|
||||||
# Install python packages' dependencies
|
# Install python packages' dependencies
|
||||||
# cv2 requires libGL.so.1
|
# cv2 requires libGL.so.1
|
||||||
RUN --mount=type=cache,id=ragflow_production_apt,target=/var/cache/apt,sharing=locked \
|
RUN --mount=type=cache,id=ragflow_production_apt,target=/var/cache/apt,sharing=locked \
|
||||||
|
@ -274,7 +274,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh slim
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔧 Build a Docker image including embedding models
|
## 🔧 Build a Docker image including embedding models
|
||||||
@ -286,7 +286,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh full
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔨 Launch service from source for development
|
## 🔨 Launch service from source for development
|
||||||
|
@ -249,7 +249,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh slim
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔧 Membangun Docker Image Termasuk Model Embedding
|
## 🔧 Membangun Docker Image Termasuk Model Embedding
|
||||||
@ -261,7 +261,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh full
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔨 Menjalankan Aplikasi dari untuk Pengembangan
|
## 🔨 Menjalankan Aplikasi dari untuk Pengembangan
|
||||||
|
@ -230,7 +230,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh slim
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔧 ソースコードをコンパイルしたDockerイメージ(埋め込みモデルを含む)
|
## 🔧 ソースコードをコンパイルしたDockerイメージ(埋め込みモデルを含む)
|
||||||
@ -242,7 +242,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh full
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔨 ソースコードからサービスを起動する方法
|
## 🔨 ソースコードからサービスを起動する方法
|
||||||
|
@ -232,7 +232,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh slim
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔧 소스 코드로 Docker 이미지를 컴파일합니다(임베딩 모델 포함)
|
## 🔧 소스 코드로 Docker 이미지를 컴파일합니다(임베딩 모델 포함)
|
||||||
@ -244,7 +244,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh full
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔨 소스 코드로 서비스를 시작합니다.
|
## 🔨 소스 코드로 서비스를 시작합니다.
|
||||||
|
@ -237,7 +237,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh slim
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔧 源码编译 Docker 镜像(包含 embedding 模型)
|
## 🔧 源码编译 Docker 镜像(包含 embedding 模型)
|
||||||
@ -249,7 +249,7 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
bash build_docker_image.sh full
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
|
|
||||||
## 🔨 以源代码启动服务
|
## 🔨 以源代码启动服务
|
||||||
|
@ -13,26 +13,51 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
import os
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
|
RAGFLOW_VERSION_INFO = "unknown"
|
||||||
|
|
||||||
|
|
||||||
def get_ragflow_version() -> str:
|
def get_ragflow_version() -> str:
|
||||||
|
global RAGFLOW_VERSION_INFO
|
||||||
|
if RAGFLOW_VERSION_INFO != "unknown":
|
||||||
|
return RAGFLOW_VERSION_INFO
|
||||||
|
version_path = os.path.abspath(
|
||||||
|
os.path.join(
|
||||||
|
os.path.dirname(os.path.realpath(__file__)), os.pardir, "VERSION"
|
||||||
|
)
|
||||||
|
)
|
||||||
|
if os.path.exists(version_path):
|
||||||
|
with open(version_path, "r") as f:
|
||||||
|
RAGFLOW_VERSION_INFO = f.read().strip()
|
||||||
|
else:
|
||||||
|
RAGFLOW_VERSION_INFO = get_closest_tag_and_count()
|
||||||
|
LIGHTEN = int(os.environ.get("LIGHTEN", "0"))
|
||||||
|
RAGFLOW_VERSION_INFO += " slim" if LIGHTEN == 1 else " full"
|
||||||
return RAGFLOW_VERSION_INFO
|
return RAGFLOW_VERSION_INFO
|
||||||
|
|
||||||
|
|
||||||
RAGFLOW_VERSION_INFO = "dev"
|
|
||||||
|
|
||||||
|
|
||||||
def get_closest_tag_and_count():
|
def get_closest_tag_and_count():
|
||||||
try:
|
try:
|
||||||
# Get the current commit hash
|
# Get the current commit hash
|
||||||
commit_id = subprocess.check_output(['git', 'rev-parse', '--short', 'HEAD']).strip().decode('utf-8')
|
commit_id = (
|
||||||
|
subprocess.check_output(["git", "rev-parse", "--short", "HEAD"])
|
||||||
|
.strip()
|
||||||
|
.decode("utf-8")
|
||||||
|
)
|
||||||
# Get the closest tag
|
# Get the closest tag
|
||||||
closest_tag = subprocess.check_output(['git', 'describe', '--tags', '--abbrev=0']).strip().decode('utf-8')
|
closest_tag = (
|
||||||
# Get the commit hash of the closest tag
|
subprocess.check_output(["git", "describe", "--tags", "--abbrev=0"])
|
||||||
closest_tag_commit = subprocess.check_output(['git', 'rev-list', '-n', '1', closest_tag]).strip().decode(
|
.strip()
|
||||||
'utf-8')
|
.decode("utf-8")
|
||||||
|
)
|
||||||
# Get the commit count since the closest tag
|
# Get the commit count since the closest tag
|
||||||
process = subprocess.Popen(['git', 'rev-list', '--count', f'{closest_tag}..HEAD'], stdout=subprocess.PIPE)
|
process = subprocess.Popen(
|
||||||
|
["git", "rev-list", "--count", f"{closest_tag}..HEAD"],
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
)
|
||||||
commits_count, _ = process.communicate()
|
commits_count, _ = process.communicate()
|
||||||
commits_count = int(commits_count.strip())
|
commits_count = int(commits_count.strip())
|
||||||
|
|
||||||
@ -41,8 +66,4 @@ def get_closest_tag_and_count():
|
|||||||
else:
|
else:
|
||||||
return f"{commit_id}({closest_tag}~{commits_count})"
|
return f"{commit_id}({closest_tag}~{commits_count})"
|
||||||
except Exception:
|
except Exception:
|
||||||
return 'unknown'
|
return "unknown"
|
||||||
|
|
||||||
|
|
||||||
if RAGFLOW_VERSION_INFO == 'dev':
|
|
||||||
RAGFLOW_VERSION_INFO = get_closest_tag_and_count()
|
|
||||||
|
@ -1,46 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
print_help() {
|
|
||||||
echo "Usage: $0 <option>"
|
|
||||||
echo " full, build full image"
|
|
||||||
echo " slim, build slim image"
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
print_help
|
|
||||||
fi
|
|
||||||
|
|
||||||
docker_version="full"
|
|
||||||
if [ "$1" == "full" ]; then
|
|
||||||
docker_version="full"
|
|
||||||
elif [ "$1" == "slim" ]; then
|
|
||||||
docker_version="slim"
|
|
||||||
else
|
|
||||||
print_help
|
|
||||||
fi
|
|
||||||
|
|
||||||
# update RAGFlow version
|
|
||||||
# Get the latest tag
|
|
||||||
last_tag=$(git describe --tags --abbrev=0)
|
|
||||||
# Get the number of commits from the last tag
|
|
||||||
commit_count=$(git rev-list --count "$last_tag..HEAD")
|
|
||||||
# Get the short commit id
|
|
||||||
last_commit=$(git rev-parse --short HEAD)
|
|
||||||
|
|
||||||
version_info=""
|
|
||||||
if [ "$commit_count" -eq 0 ]; then
|
|
||||||
version_info=$last_tag
|
|
||||||
else
|
|
||||||
printf -v version_info "%s(%s~%d)" "$last_commit" "$last_tag" $commit_count
|
|
||||||
fi
|
|
||||||
# Replace the version in the versions.py file
|
|
||||||
sed -i "s/\"dev\"/\"$version_info\"/" api/versions.py
|
|
||||||
|
|
||||||
if [ "$docker_version" == "full" ]; then
|
|
||||||
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
|
||||||
else
|
|
||||||
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
|
||||||
fi
|
|
||||||
|
|
||||||
git restore api/versions.py
|
|
@ -73,8 +73,8 @@ git clone https://github.com/infiniflow/ragflow.git
|
|||||||
cd ragflow/
|
cd ragflow/
|
||||||
pip3 install huggingface-hub nltk
|
pip3 install huggingface-hub nltk
|
||||||
python3 download_deps.py
|
python3 download_deps.py
|
||||||
docker build --build-arg ARCH=arm64 -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
docker build -f Dockerfile.slim -t infiniflow/ragflow:dev-slim .
|
||||||
docker build --build-arg ARCH=arm64 -f Dockerfile -t infiniflow/ragflow:dev .
|
docker build -f Dockerfile -t infiniflow/ragflow:dev .
|
||||||
```
|
```
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@ import urllib.request
|
|||||||
|
|
||||||
urls = [
|
urls = [
|
||||||
"http://archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_amd64.deb",
|
"http://archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_amd64.deb",
|
||||||
|
"http://ports.ubuntu.com/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_arm64.deb",
|
||||||
"https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar",
|
"https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar",
|
||||||
"https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar.md5",
|
"https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar.md5",
|
||||||
"https://openaipublic.blob.core.windows.net/encodings/cl100k_base.tiktoken",
|
"https://openaipublic.blob.core.windows.net/encodings/cl100k_base.tiktoken",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user