Angular gitlab持续集成之runner配置

gitlab持续集成

安装Runner

正常安装

sudo wget -O /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-amd64
sudo chmod +x /usr/local/bin/gitlab-runner
sudo useradd --comment 'GitLab Runner' --create-home gitlab-runner --shell /bin/bash
sudo gitlab-runner install --user=gitlab-runner --working-directory=/home/gitlab-runner
sudo gitlab-runner start
image: node:8cache:paths:- node_modules/stages:- test- buildtest:stage: testscript:- npm install- ./node_modules/@angular/cli/bin/ng test --browsers PhantomJS --watch=falsebuild:stage: buildscript:- ./node_modules/@angular/cli/bin/ng build --prod

docker in docker 安装

推荐使用此方式安装runner。

  1. pull镜像

    sudo docker pull gitlab/gitlab-runner:latest
    
  2. 创建容器运行

    docker run -d --name gitlab-runner --restart always -v /srv/gitlab-runner/config:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock gitlab/gitlab-runner:latest
    
  3. 查看注册token

    在这里插入图片描述

    在这里插入图片描述

    查看注册需要的url和token

  4. 注册runner

    sudo docker exec -it gitlab-runner gitlab-ci-multi-runner register
    

    执行完上面命令后,会交互式的让你输入相关信息,如下操作:

    #  1、输入上图中的注册URL
    Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com/):
    http://192.168.2.100:9799/# 2、输入上图中的注册令牌
    Please enter the gitlab-ci token for this runner:
    xxxxxxxxxx# 3、输入描述 如 another runner
    Please enter the gitlab-ci description for this runner:
    [gitlab]:another runner# 4、输入Runner的tag 多个的话逗号隔开
    Please enter the gitlab-ci tags for this runner (comma separated):
    my-tag# 7、选择执行类型 输入shell即可
    Registering runner... succeeded                     runner=E7XAAAAA
    Please enter the executor: docker+machine, docker-ssh, parallels, shell, ssh, virtualbox, docker-ssh+machine, kubernetes, docker:
    docker
    

    接下来选择镜像根据自己的需求,我所使用的是node:8.9.4

  5. 注册成功后,在gitlab项目中即可查看gitlab-runner

在这里插入图片描述

  1. 修改gitlab-runner容器内的配置

    进入容器内部

    sudo docker exec -it gitlab-runner /bin/bash
    

    然后编辑gitlab-runner配置文件

    nano /etc/gitlab-runner/config.toml
    

    修改如下

    concurrent = 1
    check_interval = 0[session_server]session_timeout = 1800[[runners]]name = "Angular build ^ ^ test and deploy."clone_url = "http://192.168.2.100:9799/"  # 增加此段,否则默认不带端口,会出现无法克隆项目的情况url = "http://192.168.2.100:9799/"token = "ea6a17d35baf89d3d7ddab5f026428"executor = "shell"[runners.cache][runners.cache.s3][runners.cache.gcs]

    查看runner

    gitlab-runner list
    
  2. 编写.gitlab-ci.yml然后push

    test:script:- ls
    

    在这里插入图片描述
    在这里插入图片描述

  3. 增加部署runner

    进入容器

    sudo docker exec -it gitlab-runner /bin/bash
    

    注册新的runner

    绑定/var/run/docker.sock到容器

     gitlab-runner register -n \
    > -url http://192.168.2.100:9799/ \
    > --registration-token UX91nm9za1YbgGPSymci \
    > --executor docker \
    > --description "Angular Runner" \
    > --docker-image "docker:latest" \
    > --docker-volumes /var/run/docker.sock:/var/run/docker.sock
    

    这个runner是使用宿主的docker构建镜像
    同样需要在配置文件中增加

    ...
    clone_url = "http://192.168.2.100:9799/"
    ...
    
  4. 由于gitlab runner会使用宿主机的docker下载一些镜像,以及会有一些缓存,长期使用所占的空间对于一个磁盘空间不足的机器来说是个问题,需要定时清理相应文件。可以使用自己写定时任务清理,也可以使用官方提供的cleanup镜像来定时清理。

    docker run -d \
    -e LOW_FREE_SPACE=10G \
    -e EXPECTED_FREE_SPACE=20G \
    -e LOW_FREE_FILES_COUNT=1048576 \
    -e EXPECTED_FREE_FILES_COUNT=2097152 \
    -e DEFAULT_TTL=10m \
    -e USE_DF=1 \
    --restart always \
    -v /var/run/docker.sock:/var/run/docker.sock \
    --name=gitlab-runner-docker-cleanup \
    quay.io/gitlab/gitlab-runner-docker-cleanup
    

docker不加sudo执行

  1. 如果还没有docker group就添加一个
sudo groupadd docker

2.将用户加入该group内。然后退出并重新登录就生效啦。

sudo gpasswd -a ${USER} docker

3.重启docker

sudo service docker restart

4.将gitlab-runner添加到docker组

sudo gpasswd -a gitlab-runner docker

项目的gitlab runner

[[runners]]name = "Angular Runner"url = "http://192.168.2.100:9799/"token = "a2bf55eaea82fffce1cff48b3ebf3b"executor = "docker"clone_url = "http://192.168.2.100:9799/"[runners.docker]tls_verify = falseimage = "docker:latest"privileged = falsedisable_entrypoint_overwrite = falseoom_kill_disable = falsedisable_cache = falsevolumes = ["/var/run/docker.sock:/var/run/docker.sock", "/cache"]shm_size = 0[runners.cache][runners.cache.s3][runners.cache.gcs]
[[runners]]name = "Angular test build"clone_url = "http://192.168.2.100:9799/"url = "http://192.168.2.100:9799/"token = "b2a10b9b16d5678e141bf5df636853"executor = "docker"[runners.docker]tls_verify = falseimage = "node:8.9.4"privileged = falsedisable_entrypoint_overwrite = falseoom_kill_disable = falsedisable_cache = falsevolumes = ["/cache"]shm_size = 0[runners.cache][runners.cache.s3][runners.cache.gcs]

错误

ERROR: Job failed: Error response from daemon: repository node-cnpm not found: does not exist or no pull access (executor_docker.go:168:3s)

报错的原因在于,gitlab-runner尝试去官方的docker hub仓库拉取镜像。通过修改gitlab-runner中的配置,设置只拉取本地镜像:

never, if-not-present or always (default)

修改 /etc/gitlab-runner/config.toml ,在 [runners.docker] 下,添加:

pull_policy = "if-not-present"  # 该配置默认always,即只在线上拉取镜像

gitlab-ci.yml

# 定义 stages
stages:- install_deps- test- build- deploy# 设置缓存
cache:key: ${CI_COMMIT_REF_NAME}paths:- node_modules/# 安装依赖
install_deps:stage: install_depstags:- Angular-clionly:- develop- masterscript:- npm config set registry https://registry.npm.taobao.org --global  # 设置淘宝镜像加速- npm install# 测试 job
test: # 这是 Job 的名字,不用与 stage 选项一致,也可以写成 job1stage: testtags:- Angular-cliscript:- echo "unit test successful"# 构建 job
build:stage: buildtags:- Angular-clionly:- develop- masterscript:- ./node_modules/@angular/cli/bin/ng build --prodartifacts:   # 成功后将dist发送到gitlab,供后续步骤使用name: "ioa-clent-dist"expire_in: 1 weekpaths:- dist/# 部署 job
deploy:stage: deploydependencies: - build    # 是具体的job名称,这样就会自动下载artifactstags:- Angular-Deployonly:- develop- masterscript:- sh deploy.sh

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/536024.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javascript编译压缩

javascript编译 js是JavaScript 源码文件, .min.js是压缩版的js文件。 .min.js文件经过压缩,相对编译前的js文件体积较小,传输效率快。经过编码将变量和函数原命名改为毫无意义的命名,以防止他人窥视和窃取 js 源代码 在线版 g…

vscode设置中文

vscode设置中文 当我们安装完成vscode后,会发现它是中文的,因为默认情况下,vscode使用的语言为英文(us)。 那很多同学是不喜欢英文的,不是看不懂,而是不方便哈。 修改语言配置文件 使用快捷键组合【CtrlShiftp】 在…

linux下编译boost

linux下编译boost 下载boot库 官方下载地址 下载完成会解压。 编译 1.进入解压后的文件夹内 cd boost_1_69_0 执行下面的语句 ./bootstrap.sh --with-librariesall --with-toolsetgcc–with-libraries 指定编译哪些boost库,all的话就是全部编译,只想…

C++通过原子变量代替互斥量

C通过原子变量代替互斥量 废话不多说&#xff0c;直接上代码。 实现类似lock_guard功能 #include <atomic> #include <thread>class ClockGuard { public:ClockGuard(std::atomic_flag & atomic):m_lockedFlag(atomic){lock();}~ClockGuard(){unlock();}voi…

conky安装配置

conky安装配置 安装conky sudo apt-get install conky-all修改配置 在主目录下创建’.conkyrc’ 文件内容&#xff1a; # set to yes if you want Conky to be forked in the background background no cpu_avg_samples 2 net_avg_samples 2 out_to_console no # X font w…

Windows子系统安装图形界面

Windows子系统安装图形界面 有很多同学需要使用 linux 系统,但是又不想真正安装一个 linux 系统。于是微软大哥就把 ubuntu 系统集成到 windows 内了&#xff0c;你说 微软 屌不屌&#xff1f; 言归正传。 安装Xlaunch 因为这个是最靠谱的图形化界面了&#xff0c;所以不解…

C++ 判断类是否有某变量

C 判断类是否有某变量 话不多说上代码。 #define HAS_MEMBER(member)\template<typename T, typename... Args>struct has_member_##member\ {\private:\template<typename U> static auto Check(int) -> decltype(std::declval<U>().member(std::declv…

C++将地址转换为字符串

C将地址转换为字符串 有时候在做程序设计的时候&#xff0c;有可能需要做一个类似messageBus的功能&#xff0c;并且需要一个key保证唯一&#xff0c;那么如何实现这个key的唯一呢&#xff1f;大致两种思路: 使用函数签名&#xff0c;因为messagebus绑定的是一个函数&#xf…

Angular 8之升级和新功能摘要

Angular 8之升级和新功能摘要 Angular 8已经到来,并带来了大量的工作流程和性能改进。就像我们之前发布的几个版本一样,让我们回顾一下Angular 8的新功能,以及如何将Angular 7应用程序升级到Angular 8。 Angular 8中明显的新功能数量有限,但确实还有一些好东西: Differen…

Linux下查看显卡PCIE速率x16x8x4及设定

Linux下查看显卡PCIE速率x16x8x4 由于linux软件并不是很齐全所以查看显卡占用PCIE的带宽并不直观&#xff0c;所以本文介绍如何查看。 Windows下使用GPU-Z即可查看 Linux 确定当前显卡型号 lspci | grep NVIDIA返回 02:00.0 3D controller: NVIDIA Corporation GM107M [GeFor…

Deepin安装最新显卡RTX2080Ti及CUDA10.1

Deepin安装最新显卡RTX2080Ti及CUDA10.1 废话不多说直接上教程。 本系统为Deepin 15.10.2&#xff0c;是基于debian 9发布的&#xff0c;不排除后续deepin升级为debian 10&#xff0c;就目前来看是和ubuntu 16.04一样&#xff0c;使用的是debian 9&#xff0c;所以下载安装包等…

Anaconda安装Tensorflow环境

Anaconda安装Tensorflow环境 Anaconda安装 下载安装包&#xff0c;请到这个地址下载 安装 打开终端执行&#xff1a; bash Anaconda3-5.3.1-Linux-x86_64.sh安装过程全部yes即可。 然后重新启动。 验证是否安装成功 conda --version如果没有报错&#xff0c;并且输出下面内容…

Windows下Qt Creator设置IDE菜单字体样式

Windows下Qt Creator设置IDE菜单字体样式 本文为解决以下问题&#xff1a; IDE的菜单字体太小IDE的菜单字体样式&#xff0c;可以更换为微软雅黑 创建样式文件 在Qt Creator目录下C:\Qt\Qt5.12.2创建 custom-style.css 文件&#xff0c;内容如下&#xff1a; QWidget { fo…

Clonezilla再生龙备份与还原linux系统

文章目录Clonezilla再生龙备份与还原linux系统简介功能与要求一、制作再生龙启动盘1.下载镜像2.制作启动盘二、系统分区三、备份系统四、还原系统注意事项Clonezilla再生龙备份与还原linux系统 简介 再生龙&#xff08;Clonezilla&#xff09;是一个免费的灾难恢复、硬盘克隆…

ubuntu Qt Creator不能输入中文

ubuntu Qt Creator不能输入中文 解决方式为下面的脚本&#xff0c;如果你的Qt是安装在根目录下&#xff0c;那么需要加sudo&#xff0c;如果不是&#xff0c;直接运行即可 sudo bash ChineseInputForQt-v1.1.sh# 或者bash ChineseInputForQt-v1.1.sh脚本内容为&#xff1a; …

修改gitlab数据卷的位置

修改gitlab数据卷的位置 在使用docker安装gitlab的时候&#xff0c;一开始没有考虑其他事情&#xff0c;直接在本地创建了一个数据卷就挂载到容器上了&#xff0c;导致后续数据越来越多&#xff0c;想将数据放到其他盘&#xff0c;大致可以这样操作。 1.停止容器 docker sto…

Angular安装教程

Angular安装 安装node和npm 参考这篇文章安装 https://blog.csdn.net/wf19930209/article/details/84226365 正式安装 当然&#xff0c;在安装 angular/cli 之前需要先把 Node.js 安装好&#xff0c;请到官方网站下载安装包 &#xff0c;安装过程和普通软件没有区别。装好…

Angular之ngx-permissions安装入门

Angular之ngx-permissions安装入门 权限帮助您对路线的控制权,通过使用简单的概念,你来决定谁可以访问它们。 安装 安装这个第三方库: npm install ngx-permissions --save导入 App Module导入 import {BrowserModule } from @angular/platform-browser; import {NgMo…

Angular之ngx-permissions的常见使用情况

Angular之ngx-permissions的常见使用情况 权限验证 首先需要请求验证并通过&#xff0c;然后获得权限&#xff0c;最后检查权限。 这种方式需要在Angular 4.3.2 版本以上才会有效工作。 一般来说我们的程序有2个守卫&#xff0c;一个是信息验证&#xff0c;一个是权限守卫&am…

Angular之ngx-permissions的控制视图访问

Angular之ngx-permissions的控制视图访问 案例 demo https://stackblitz.com/edit/ngx-permissions-iwexsb Permission指令 Permission模块将导出指令 ngxPermissionsOnly 和 ngxPermissionsExcept,它能够根据权限和角色控制元素的显示/隐藏。 指令属性 属性值描述ngxPerm…