2019.3.20总结
gitlab-ci.yml :
gitlab 提供持续集成服务,如果添加一个.gitlab-ci.yml文件到项目根目录,并配置gitlab项目使用某个runner,然后每一次提交或者是推送都会触发
CI pipeline.
.gitlab-ci.yml 文件会告诉gitlab runner做什么,默认情况,它运行一个pipeline,分为三个阶段:build,test,deploy.没有job的阶段会被忽略
如果一切运行正常(没有非零的返回值),您将得到与commit关联的漂亮的绿色标记。这使得在查看代码之前,很容易就能看出是否有一个提交导致了测试失败
简而言之,CI所需要的步骤可以归结为:
1. 添加.gitlab-ci.yml
到项目的根目录
2. 配置一个Runner
从此刻开始,在每一次push到Git仓库的过程中,Runner会自动开启pipline,pipline将显示在项目的Pipline页面
.gitlab-ci.yml是什么
注意:.gitlab-ci.yml
是一个YAML文件,所以必须要格外注意锁紧。使用空格,而不是tabs。
保留字 | 必填 | 介绍 |
---|---|---|
image | 否 | 构建使用的Docker镜像名称,使用Docker )作为Excutor时有效} |
services | 否 | 使用的Docker服务,使用Docker 作为Excutor时有效 |
stages | 否 | 定义构建的stages |
types | 否 |
stages 的别名 |
before_script | 否 | 定义所有job执行之前需要执行的脚本命令 |
after_script | 否 | 定义所有job执行完成后需要执行的脚本命令 |
variables | 否 | 定义构建变量 |
cache | 否 | 定义一组文件,该组文件会在运行时被缓存,下次运行仍然可以使用 |
关键字 | 必要性 | 介绍 |
---|---|---|
script | 是 | 定义了Runner会执行的脚本命令 |
image | 否 | 使用Docker镜像,多内容参考使用Docker镜像 |
services | 否 | 使用Docker服务,更多内容参考 使用Docker镜像 |
stage | 否 | 定义构建的stage(默认:test ) |
type | 否 |
stage 的别名 |
variables | 否 | 定义job级别的环境变量 |
only | 否 | 定义一组构建会创建的git refs 设置了需要被构建的branches和tags的名称。 |
except | 否 | 定义一组构建不会创建的git refs 设置了不需要被构建的branches和tags的名称 |
tags | 否 | 定义一组tags用于选择合适的Runner |
allow_failure | 否 | 允许构建失败。失败的构建不会影响提交状态。 |
when | 否 | 定义什么时候执行构建。可选:on_success 、on_failure 、always 、manual
|
dependencies | 否 | 定义当前构建依赖的其他构建,然后你可以在他们之间传递artifacts |
artifacts | 否 | 定义一组构建artifact。 |
cache | 否 | 定义一组可以缓存以在随后的工作中共享的文件 |
before_script | 否 | 覆写全局的before_script命令 |
after_script | 否 | 覆写全局的after_script命令 |
environment | 否 | 定义当前构建完成后的运行环境的名称 |
Dockerfile :
docker 镜像是一个特殊的文件系统,除了提供容器运行时所需要的程序,库,资源配置等文件
外,还包含了一些为运行时准备的一些配置参数(如匿名卷,环境变量,用户等).镜像不包含任何
动态数据,其内容在构建后也不会被改变.
镜像的定制实际上就是定制每一层所添加的配置,文件.如果我们可以把每一层修改,安装,构建
操作的命令都写入一个脚本,用这个脚本构建,定制镜像,那么之前提及的无法重复的问题,镜像构建
透明性的问题,体积的问题就都会解决,这个脚本就是Dockerfile
dockerfile是一个文本文件,其内包含了一条条的指令,每一条指令构建一层,因此每一条指令
的内容,就是描述该层应当如何构建,有dockerfile,当我们需要定制自己额外的需求时,只需要
在dockerfile上添加或者修改指令,重新生成image即可.
构建Nginx运行环境
# 指定基础镜像
FROM sameersbn/ubuntu:14.04.20161014
# 维护者信息
MAINTAINER sameer@damagehead.com
# 设置环境
ENV RTMP_VERSION=1.1.10 \
NPS_VERSION=1.11.33.4 \
LIBAV_VERSION=11.8 \
NGINX_VERSION=1.10.1 \
NGINX_USER=www-data \
NGINX_SITECONF_DIR=/etc/nginx/sites-enabled \
NGINX_LOG_DIR=/var/log/nginx \
NGINX_TEMP_DIR=/var/lib/nginx \
NGINX_SETUP_DIR=/var/cache/nginx
# 设置构建时变量,镜像建立完成后就失效
ARG BUILD_LIBAV=false
ARG WITH_DEBUG=false
ARG WITH_PAGESPEED=true
ARG WITH_RTMP=true
# 复制本地文件到容器目录中
COPY setup/ ${NGINX_SETUP_DIR}/
RUN bash ${NGINX_SETUP_DIR}/install.sh
# 复制本地配置文件到容器目录中
COPY nginx.conf /etc/nginx/nginx.conf
COPY entrypoint.sh /sbin/entrypoint.sh
# 运行指令
RUN chmod 755 /sbin/entrypoint.sh
# 允许指定的端口
EXPOSE 80/tcp 443/tcp 1935/tcp
# 指定网站目录挂载点
VOLUME ["${NGINX_SITECONF_DIR}"]
ENTRYPOINT ["/sbin/entrypoint.sh"]
CMD ["/usr/sbin/nginx"]