Azure 如何创建没有特定参数的通用docker图像
我使用一个名为Camunda的工作流引擎和一个docker映像,这个工具连接到一个Azure SQL实例,我用下面的代码创建了映像(出于安全目的删除了一些信息) 然后我将映像推送到Azure容器注册表,它非常适合我们的开发环境 但是,我希望在我们的暂存和生产环境中使用相同的映像 如何使用变量从docker文件中删除连接字符串settins,然后在部署时替换这些变量Azure 如何创建没有特定参数的通用docker图像,azure,docker,containers,camunda,Azure,Docker,Containers,Camunda,我使用一个名为Camunda的工作流引擎和一个docker映像,这个工具连接到一个Azure SQL实例,我用下面的代码创建了映像(出于安全目的删除了一些信息) 然后我将映像推送到Azure容器注册表,它非常适合我们的开发环境 但是,我希望在我们的暂存和生产环境中使用相同的映像 如何使用变量从docker文件中删除连接字符串settins,然后在部署时替换这些变量 FROM alpine:3.10 as builder ARG VERSION=7.12.0 ARG DISTRO=tomcat
FROM alpine:3.10 as builder
ARG VERSION=7.12.0
ARG DISTRO=tomcat
ARG SNAPSHOT=true
ARG EE=false
ARG USER
ARG PASSWORD
RUN apk add --no-cache \
ca-certificates \
maven \
tar \
wget \
xmlstarlet
COPY settings.xml download.sh camunda-tomcat.sh camunda-wildfly.sh /tmp/
RUN /tmp/download.sh
#Enable Basic AUTH
COPY web.xml /camunda/webapps/engine-rest/WEB-INF/web.xml
##### FINAL IMAGE #####
FROM alpine:3.10
ARG VERSION=7.12.0
ENV CAMUNDA_VERSION=${VERSION}
ENV DB_DRIVER=com.microsoft.sqlserver.jdbc.SQLServerDriver
ENV DB_URL=jdbc:sqlserver://servername.database.windows.net:1433;database=abc;user=username@servername;password={bcd};encrypt=true;trustServerCertificate=false;hostNameInCertificate=*.database.windows.net;loginTimeout=30;
ENV DB_USERNAME=username@servername
ENV DB_PASSWORD=bcd
ENV DB_CONN_MAXACTIVE=20
ENV DB_CONN_MINIDLE=5
ENV DB_CONN_MAXIDLE=20
ENV DB_VALIDATE_ON_BORROW=true
ENV DB_VALIDATION_QUERY="SELECT 1"
ENV SKIP_DB_CONFIG=
ENV WAIT_FOR=
ENV WAIT_FOR_TIMEOUT=120
ENV TZ=UTC
ENV DEBUG=TRUE
ENV JAVA_OPTS="-Xmx768m -XX:MaxMetaspaceSize=256m"
EXPOSE 8080 8000
# Downgrading wait-for-it is necessary until this PR is merged
# https://github.com/vishnubob/wait-for-it/pull/68
RUN apk add --no-cache \
bash \
ca-certificates \
openjdk11-jre-headless \
tzdata \
tini \
xmlstarlet \
&& wget -O /usr/local/bin/wait-for-it.sh \
"https://raw.githubusercontent.com/vishnubob/wait-for-it/a454892f3c2ebbc22bd15e446415b8fcb7c1cfa4/wait-for-it.sh" --no-check-certificate \
&& chmod +x /usr/local/bin/wait-for-it.sh
RUN addgroup -g 1000 -S camunda && \
adduser -u 1000 -S camunda -G camunda -h /camunda -s /bin/bash -D camunda
WORKDIR /camunda
USER camunda
#MSSQL SERVER JDBC DRIVER INSTALL
COPY mssql-jdbc-7.2.2.jre11.jar /camunda/lib/
ENTRYPOINT ["/sbin/tini", "--"]
CMD ["./camunda.sh"]
COPY --chown=camunda:camunda --from=builder /camunda .