搜索
首页后端开发Golang如何使用 SSH 在 Docker 中使用私有 GitLab 模块构建 Go 应用程序?

How to Build Go Apps with Private GitLab Modules in Docker using SSH?

在 Docker 中使用私有 GitLab 模块构建 Go 应用

本指南旨在解决将私有 GitLab 模块集成到 Go 应用程序时面临的特定挑战在 Docker 中。

了解问题

当 Dockerfile 尝试从 GitLab 提取私有包,但尽管遵循类似的 GitHub 教程但身份验证失败时,就会出现此问题。这个具体问题源于 GitHub 和 GitLab 的身份验证机制之间的差异。

建议的解决方案

为了解决这个问题,我们将利用基于 SSH 的身份验证并采用 Docker 的实验功能。

实验性 Docker功能

通过在 Dockerfile 开头添加以下注释来启用实验性 Docker 功能:

# syntax=docker/dockerfile:experimental

Dockerfile 设置

  1. 确保您的构建环境有openssh-client:
RUN apk --no-cache add build-base git mercurial gcc curl openssh-client
  1. 建立known_hosts并配置.gitconfig:
RUN mkdir -p -m 0700 ~/.ssh && \
    ssh-keyscan gitlab.com >> ~/.ssh/known_hosts && \
    echo -e "[url \"[email protected]:<company-name>\"]\n\tinsteadOf = https://gitlab.com/<company-name>\"" >> ~/.gitconfig</company-name></company-name>
  1. 使用基于SSH的构建你的Go应用程序身份验证:
ENV GO111MODULE=on
ENV GOPRIVATE=gitlab.com/<company-name>
RUN --mount=type=ssh cd cmd/app/ && go build -o app</company-name>

在 ssh-agent 中加载密钥

在构建 Docker 镜像之前,必须将私钥加载到 ssh-agent 中:

ssh-add id_rsa

构建 Docker镜像

使用以下命令构建 Docker 镜像:

DOCKER_BUILDKIT=1 docker build --progress=plain .

调试 SSH 连接

如果出现 SSH 连接问题,请添加以下调试命令到您的Dockerfile:

RUN ssh -A -v -l git gitlab.com

解决 AppArmor 问题

如果 apparmor 阻止 Docker 访问 SSH 密钥套接字,请编辑 apparmor 配置文件并在关闭 }:

/run/user/1000/keyring/ssh rw,

密钥文件名问题

确保私钥文件名是 SSH 期望的默认值之一(例如 id_rsa)或使用 .ssh/config 文件将自定义密钥名称映射到预期的默认值。

附加说明

避免使用 chmod授予权限,因为 SSH 密钥条目足以共享私钥。还建议避免使用 .netrc,因为它将凭据嵌入到 Docker 映像中,可能会危及安全性。

以上是如何使用 SSH 在 Docker 中使用私有 GitLab 模块构建 Go 应用程序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
使用GO开发时的安全考虑使用GO开发时的安全考虑Apr 27, 2025 am 12:18 AM

Gooffersrobustfeaturesforsecurecoding,butdevelopersmustimplementsecuritybestpracticeseffectively.1)UseGo'scryptopackageforsecuredatahandling.2)Manageconcurrencywithsynchronizationprimitivestopreventraceconditions.3)SanitizeexternalinputstoavoidSQLinj

了解GO的错误接口了解GO的错误接口Apr 27, 2025 am 12:16 AM

Go的错误接口定义为typeerrorinterface{Error()string},允许任何实现Error()方法的类型被视为错误。使用步骤如下:1.基本检查和记录错误,例如iferr!=nil{log.Printf("Anerroroccurred:%v",err)return}。2.创建自定义错误类型以提供更多信息,如typeMyErrorstruct{MsgstringDetailstring}。3.使用错误包装(自Go1.13起)来添加上下文而不丢失原始错误信息,

并发程序中的错误处理并发程序中的错误处理Apr 27, 2025 am 12:13 AM

对效率的Handleerrorsinconcurrentgopragrs,UsechannelstocommunicateErrors,EmparterRorwatchers,InsterTimeouts,UsebufferedChannels和Provideclearrormessages.1)USEchannelelStopassErstopassErrorsErtopassErrorsErrorsFromGoroutInestotheStothemainfunction.2)

您如何在GO中实现接口?您如何在GO中实现接口?Apr 27, 2025 am 12:09 AM

在Go语言中,接口的实现是通过隐式的方式进行的。1)隐式实现:类型只要包含接口定义的所有方法,就自动满足该接口。2)空接口:interface{}类型所有类型都实现,适度使用可避免类型安全问题。3)接口隔离:设计小而专注的接口,提高代码的可维护性和重用性。4)测试:接口有助于通过模拟依赖进行单元测试。5)错误处理:通过接口可以统一处理错误。

将GO接口与其他语言的接口进行比较(例如Java,C#)将GO接口与其他语言的接口进行比较(例如Java,C#)Apr 27, 2025 am 12:06 AM

go'sinterfacesareimpliclyimplysed,与Javaandc#wheRequireexplitiCimplation.1)Ingo,AnyTypewithTheRequiredMethodSautSautsautautapitymethodimimplementalyimimplementsaninternItherninternionterface,callingingSimplicity andficityity.2)

初始功能和副作用:平衡初始化与可维护性初始功能和副作用:平衡初始化与可维护性Apr 26, 2025 am 12:23 AM

Toensureinitfunctionsareeffectiveandmaintainable:1)Minimizesideeffectsbyreturningvaluesinsteadofmodifyingglobalstate,2)Ensureidempotencytohandlemultiplecallssafely,and3)Breakdowncomplexinitializationintosmaller,focusedfunctionstoenhancemodularityandm

开始GO:初学者指南开始GO:初学者指南Apr 26, 2025 am 12:21 AM

goisidealforbeginnersandsubableforforcloudnetworkservicesduetoitssimplicity,效率和concurrencyFeatures.1)installgromtheofficialwebsitealwebsiteandverifywith'.2)

进行并发模式:开发人员的最佳实践进行并发模式:开发人员的最佳实践Apr 26, 2025 am 12:20 AM

开发者应遵循以下最佳实践:1.谨慎管理goroutines以防止资源泄漏;2.使用通道进行同步,但避免过度使用;3.在并发程序中显式处理错误;4.了解GOMAXPROCS以优化性能。这些实践对于高效和稳健的软件开发至关重要,因为它们确保了资源的有效管理、同步的正确实现、错误的适当处理以及性能的优化,从而提升软件的效率和可维护性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。