一张 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
我想在 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