gpt4 book ai didi

postgresql - 一个 docker 图像中带有 liquibase 的 Postgres

转载 作者:行者123 更新时间:2023-12-04 14:12:29 31 4
gpt4 key购买 nike

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

现在我创建 Dockerfile 如下

FROM postgres
ADD /changelog /liquibase/changelog

我不明白如何向这张图片添加 liquibase?或者我必须使用 docker compose?或 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"]

主程序

#!/bin/bash

bash liquibase.sh | awk '{print "liquiBase script: " $0}' &

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

关于postgresql - 一个 docker 图像中带有 liquibase 的 Postgres,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63152535/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com