我已经有了一个用于nginx的自定义图像的docker文件,这个文件工作得很好。
FROM library/nginx:1.13.2
LABEL maintainer="san@test.com"
# Remove the default Nginx configuration file
RUN rm -v /etc/nginx/nginx.conf
# Copy a configuration file from the current directory
ADD nginx.conf /etc/nginx/
# forward request and error logs to docker log collector
RUN ln -sf /dev/stdout /var/log/nginx/access.log \
&& ln -sf /dev/stderr /var/log/nginx/error.log \
# Make PageSpeed cache writable
&& mkdir -p /var/cache/ngx_pagespeed && \
chmod -R o+wr /var/cache/ngx_pagespeed
ADD server.crt /etc/nginx/ssl/
ADD server.key /etc/nginx/ssl/
ADD conf.d/ /etc/nginx/conf.d/
ADD proxy.d/ /etc/nginx/proxy.d/
CMD ["nginx", "-g", "daemon off;"]我还在尝试安装aws cli,这样我就可以复制一些s3文件并动态更改nginx配置,一旦CMD[]在容器中可用,我将对awsCli执行这些操作。
我尝试并阅读了许多来自谷歌的链接,但文档或阅读并没有帮助,特别是如何让证书通过。
我用两种方式创建图像。首先是通过jenkins管道(下面是代码片段
stages {
stage('Build Docker image') {
steps {
script {
docker.withRegistry("http://xyz-1.amazonaws.com", "ecr:eu-central-1:aws-credentials") {
def customImage = docker.build("web-proxy:${CY_RELEASE_VERSION}", ".")
customImage.push()
}
}
}
}另一种方式是在本地手动构建镜像,如下所示
docker build -t web-proxy-dev_san_1:1.11 .我不确定的是如何在DockerFile中使用aws-cli,并让镜像在本地和jenkins中自动获取凭据。我认为对于jenkins来说,如果我在使用管道中指定的aws-credentials时设法安装aws-cli,它可能会起作用,但我还没有达到那个阶段。
发布于 2021-07-16 23:35:49
您可以使用亚马逊网络服务插件在您的管道中与亚马逊网络服务进行交互,请检查以下示例:link
https://stackoverflow.com/questions/68411274
复制相似问题