Dockerfile 2.18 KB
Newer Older
1
# Use the official Ubuntu base image
2
FROM ubuntu:22.04
3
4
5
6
7
8

# Set environment variables to non-interactive to avoid prompts during installation
ENV DEBIAN_FRONTEND=noninteractive
ENV LANG C.UTF-8

# Update the package list and install necessary packages
9
10
11
12
13
14
15
16
RUN apt-get -q update && \
    apt-get -q install -y --no-install-recommends \
        build-essential \
        software-properties-common \
        # gpg \
    # && add-apt-repository ppa:deadsnakes/ppa \
    && apt-get update \
    && apt-get install -y \
17
18
19
20
21
22
23
24
        python3.10 \
        python3.10-venv \
        python3.10-distutils \
        python3-pip \
        wget \
        git \
        libgl1 \
        libglib2.0-0 \
25
26
    && apt-get clean \
    && rm -rf /var/lib/apt/lists/*
27
28
29
30

# Set Python 3.10 as the default python3
RUN update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.10 1

31
32
33
34
# Create a virtual environment for MinerU and install packages
RUN python3 -m venv /opt/mineru_venv && \
    pip config set global.index-url https://mirrors.aliyun.com/pypi/simple && \
    /bin/bash -c "source /opt/mineru_venv/bin/activate && \
35
    pip install --upgrade pip && \
36
37
38
39
    pip install magic-pdf[full] --extra-index-url https://myhloli.github.io/wheels/ --no-cache-dir && \
    pip install fastapi uvicorn python-multipart --no-cache-dir && \
    pip uninstall paddlepaddle -y && \
    pip install paddlepaddle-gpu==3.0.0b1 -i https://www.paddlepaddle.org.cn/packages/stable/cu118/ --no-cache-dir"
40
41

# Copy the configuration file template and set up the model directory
42
43
44
45
46
COPY models/models /opt/models
COPY layoutreader /opt/layoutreader
COPY .paddleocr /root/.paddleocr 
COPY app.py /root/app.py
COPY magic-pdf.json /root/magic-pdf.json
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62

WORKDIR /root


# Create the models directory
# RUN mkdir -p /opt/models

# Set the entry point to activate the virtual environment and run the command line tool
# ENTRYPOINT ["/bin/bash", "-c", "source /opt/mineru_venv/bin/activate && exec \"$@\" && python3 app.py", "--"]


# Expose the port that FastAPI will run on
EXPOSE 8000

# Command to run FastAPI using Uvicorn, pointing to app.py and binding to 0.0.0.0:8000
CMD ["/bin/bash", "-c", "source /opt/mineru_venv/bin/activate && uvicorn app:app --host 0.0.0.0 --port 8000"]