db / Dockerfile
aigenai's picture
Update Dockerfile
40c7d94 verified
raw
history blame
2.28 kB
# 使用 PostgreSQL 官方镜像
FROM postgres:latest
# 设置环境变量,用于数据库配置
ENV POSTGRES_USER=myuser \
POSTGRES_PASSWORD=mypassword \
POSTGRES_DB=mydatabase \
VIRTUAL_ENV=/opt/venv \
PATH="$VIRTUAL_ENV/bin:$PATH"
# 切换到 root 用户进行安装和用户修改
USER root
# 更新包管理器并安装必要软件包,包括 Python3、venv、curl、Node.js、n8n
RUN apt-get update && apt-get install -y \
python3 \
python3-pip \
python3-venv \
curl \
gosu \
build-essential \
&& apt-get clean && rm -rf /var/lib/apt/lists/*
# 安装 Node.js 及 n8n
RUN curl -fsSL https://deb.nodesource.com/setup_20.x | bash - && \
apt-get install -y nodejs && \
npm install -g n8n && \
apt-get clean && rm -rf /var/lib/apt/lists/*
# 更改现有的 postgres 用户 UID 和 GID 为 1000
RUN usermod -u 1000 postgres && groupmod -g 1000 postgres
# 修正数据库目录的所有者和组,确保新 UID 和 GID 能正常访问
RUN chown -R postgres:postgres /var/lib/postgresql && \
chown -R postgres:postgres /var/run/postgresql
# 切换到 postgres 用户,初始化数据库并创建角色
USER postgres
# 初始化 PostgreSQL 数据库,并创建指定的用户角色和数据库
RUN initdb -D /var/lib/postgresql/data && \
pg_ctl start -D /var/lib/postgresql/data && \
psql --command "CREATE ROLE $POSTGRES_USER WITH LOGIN SUPERUSER PASSWORD '$POSTGRES_PASSWORD';" && \
createdb -O $POSTGRES_USER $POSTGRES_DB && \
pg_ctl stop -D /var/lib/postgresql/data
# 切换回 root 用户以安装 Python 依赖
USER root
# 创建虚拟环境并安装 Python 包
RUN python3 -m venv $VIRTUAL_ENV && \
$VIRTUAL_ENV/bin/pip install --upgrade pip && \
$VIRTUAL_ENV/bin/pip install psycopg2-binary
# 将应用程序代码和启动脚本复制到容器中
COPY app.py /app/app.py
COPY run.sh /app/run.sh
# 设置脚本可执行权限
RUN chmod +x /app/run.sh
# 切换到更改后的 postgres 用户
USER postgres
# 设置工作目录
WORKDIR /app
# 启动容器时执行run.sh脚本
CMD ["./run.sh"]
# 设置健康检查以确保 Flask 应用正常运行
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:7860/ || exit 1