当前位置: 首页 > news >正文

东莞公司网站制作公司设计工作室宣传文案

东莞公司网站制作公司,设计工作室宣传文案,芜湖手机网站制作,网站首页标题字数文章目录 前言配置流程注册ssh-keygit runner映射文件方法1 .gitlab-ci.yml使用方法2 docker build 实现 总结 前言 之所以写这篇文章是由于存在以下场景: 当前的项目编译需要依赖别的项目协同编译,如何将别的项目也pull到该项目里,编译成品…

文章目录

  • 前言
  • 配置流程
    • 注册ssh-key
    • git runner映射文件
    • 方法1 .gitlab-ci.yml使用
    • 方法2 docker build 实现
  • 总结

前言

之所以写这篇文章是由于存在以下场景:

当前的项目编译需要依赖别的项目协同编译,如何将别的项目也pull到该项目里,编译成品如何打包镜像并保存到registry中。

本文主要写在某项目进行CI流程编译时,如何拉取该项目依赖项目,中间会涉及到gitlab-runner的配置,runner运行服务器的配置,CI(.gitlab-ci.yml)流程文件编写,Dockerfile文件编写等。

配置流程

注册ssh-key

新注册一个gitlab_ci的账户拥有admin权限,在gitrunnr运行的服务器上生成新的ssh-key,博主使用的是ssh-rsa。生成添加方法可以参考如下博文——简单易用多git服务器ssh密钥配置管理

该文件保存在~/.ssh/id_rsa

git runner映射文件

[[runners]]name = "build"url = "http://gitlab.DOMAIN.com/"id = 7token = "*********"token_obtained_at = 2023-05-17T08:02:32Ztoken_expires_at = 0001-01-01T00:00:00Zexecutor = "docker"[runners.cache]MaxUploadedArchiveSize = 0[runners.docker]tls_verify = falseimage = "registry.gitlab.DOMAIN.com/docker_git:latest"#pull_policy = "if-not-present"privileged = falsedisable_entrypoint_overwrite = falseoom_kill_disable = falsedisable_cache = falsevolumes = ["/cache","/home/dev/.ssh:/home/dev/.ssh","/var/run/docker.sock:/var/run/docker.sock"]shm_size = 0

这里添加.ssh文件夹的映射,docker.sock lock在docker in docker时使用。

方法1 .gitlab-ci.yml使用

.build:image: registry.gitlab.DOMAIN.com/docker_git:lateststage: testbefore_script:- 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client git -y )'- eval $(ssh-agent -s)- ssh-add ~/.ssh/id_rsa- ssh -T git@gitlab.DOMAIN.comafter_script:- rm -rf build install

跑CI可以看到输出的ssh访问成功

Welcome to GitLab, @gitlab_ci!

本文结合如下几种方法综合实现,官网教程如下:

Using SSH keys with GitLab CI/CD| GitLab

Docker executor | GitLab

方法2 docker build 实现

这个需要在方法一的基础上去做,大概原理是通过ssh-agent做代理,docker build时将ssh相关参数传入docker中使其能够调用ssh-key。

ssh -vvT会打印更多详细信息。Dockerfile如下所示

# syntax=docker/dockerfile:1
FROM alpine
RUN apk add --no-cache openssh-client
RUN mkdir -p -m 0700 ~/.ssh && ssh-keyscan gitlab.com >> ~/.ssh/known_hosts
RUN --mount=type=ssh \ssh -vvT git@gitlab.DOMAIN.com 

参考CI执行脚本如下:

.build:image: registry.gitlab.DOMAIN.com/docker_git:lateststage: testbefore_script:- 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client git -y )'- eval $(ssh-agent -s)- ssh-add ~/.ssh/id_rsa- IMAGE_NAME=$CI_REGISTRY_IMAGE/test:v0.0.1- docker buildx build --ssh default=$SSH_AUTH_SOCK .- docker push $IMAGE_NAMEafter_script:- docker rmi $IMAGE_NAME

这两种写法均可,根据习惯选择。

# 写法1
docker buildx build --ssh default=$SSH_AUTH_SOCK .
# 写法2
DOCKER_BUILDKIT=1 docker build --ssh default=$SSH_AUTH_SOCK .

注意image需要安装buildx否则会报错,可以参考如何建立并使用docker

docker build 的整体官方教程如下:

Dockerfile reference | Docker Docs

总结

本篇博文整理一种相对简单实现目标需求的方法,其实还有使用CI Job token1,生命周期短并且可以通过Settings -> CI/CD -> Token Access -> Limit access to this project设置该token作用范围。

通过CI/CD Variables 去设置SSH_PRIVATE_KEY等方式,大家有兴趣可以深入研究。以后该部分也会持续跟新,随着实际生产加工环境逐步优化。


  1. GitLab CI/CD job token | GitLab ↩︎

http://www.yayakq.cn/news/821178/

相关文章:

  • 沧州网站建设公司翼马wordpress 弹窗打开
  • 网站后台更新没有变化wordpress share
  • 用js来做网站外贸网站如何做推广是什么意思
  • wordpress站长网站建设行业前景如何
  • 建网站的程序免费厨之梦进口食品网站谁做的
  • 淘宝客网站搜索怎么做html首页代码
  • 可以做机械设计接单的网站网站后台左侧导航折叠效果打不开
  • 网站设计与系统的区别东阳市住房和城乡建设局网站
  • 网站开发需求用什么软件凡科做的网站好吗
  • 新零售型网站开发手机网站建设进度
  • 有没有教做零食的网站app开发自学教程
  • 新建设电影院+网站网站内容与功能设计
  • 国内知名的wordpress网站图床网站怎么做
  • 中国建设执业资格注册中心网站iis做网站视
  • 界面做的最好的网站公司网站市场价
  • 计算机网络 网站创建网页的三种方法
  • 网站免费推广策划方案南京中企动力有限公司
  • 网站维护提示怎么做用wordpress建的网站
  • 企业网站管理是什么网站标题关键字
  • 沈阳网站设计制作手机网站开发计划
  • 网站屏蔽ip地址广告创意策划
  • 免费浪漫网页制作网站通辽建设工程网站
  • 网站怎么推广比较好做网站外链需要多少钱
  • 如何制作局域网站wordpress widget logic
  • 网站建设推广选stso88效果好上海羽贝网站建设
  • 企业网站备案域名可以用个人的怎样制作免费网页
  • 展示型的网站开发价格文山知名网站建设公司
  • 网站维护需要的知识网站建设企业 熊账号
  • 漳州 网站建设多少钱大连网站开发哪儿好薇
  • 大学生课程设计网站济南优化官网公司