一张 docker 图像中带有 liquibase 的 Postgres

Postgres with liquibase in one docker image

我想在 kubernetes 中为自动测试创建数据库。我想从 postgres 图像创建图像(postg-my-app-v1),添加更改日志文件和 liquibase 图像。当我用 helm 部署这个图像时,我只想指定容器 - postg-my-app-v1 并且它应该使用数据库启动 pod 并使用 liquibase changelog 创建表。

现在我创建 Dockerfile 如下

FROM postgres
ADD /changelog /liquibase/changelog

我不明白如何向这张图片添加 liquibase?或者我必须使用 docker 撰写?或 liquibase 的 helm lifecycle postStart?

FROM docker-proxy.tcsbank.ru/liquibase/liquibase:3.10.x AS Liquibase

FROM docker-proxy.tcsbank.ru/postgres:9.6.12 AS Postgres
ENV POSTGRES_DB bpm
ENV POSTGRES_USER priest
ENV POSTGRES_PASSWORD Bpm_123


COPY --from=Liquibase /liquibase /liquibase

ENV JAVA_HOME /usr/local/openjdk-11
COPY --from=Liquibase $JAVA_HOME $JAVA_HOME


ENV LIQUIBASE_CHANGELOG /liquibase/changelog/
COPY /changelog $LIQUIBASE_CHANGELOG


COPY liquibase.sh /usr/local/bin/
COPY main.sh /usr/local/bin/

RUN chmod +x /usr/local/bin/liquibase.sh && \
    chmod +x /usr/local/bin/main.sh && \
    ln -s /usr/local/bin/main.sh / && \
    ln -s /usr/local/bin/liquibase.sh /

ENTRYPOINT ["main.sh"]

main.sh

#!/bin/bash

bash liquibase.sh | awk '{print "liquiBase script: " [=11=]}' &

bash docker-entrypoint.sh postgres

liquibase.sh

#!/bin/bash

for COUNTER in {1..120}
do
   sleep 1s
   echo "check db $COUNTER times"
   pg_isready
   if [ $? -eq 0 ]
   then
     break
   fi
done

echo "try execute liquibase"
bash liquibase/liquibase --url="jdbc:postgresql://localhost:5432/$POSTGRES_DB"  --username=$POSTGRES_USER --password=$POSTGRES_PASSWORD --changeLogFile=/liquibase/changelog/changelog.xml update