Docker 将ca证书添加到drone.io构建容器,以便git fetch可以使用它?

Docker 将ca证书添加到drone.io构建容器,以便git fetch可以使用它?,docker,ssl-certificate,drone,Docker,Ssl Certificate,Drone,我有一个本地gitlab节点和一个本地drone.io节点。 drone.io节点在ubuntu上运行。 gitlab节点使用自签名证书。 我已经以规范的ubuntu方式将证书添加到drone.io节点(cp cert.pem/usr/share/ca certificates/;更新ca证书)。 无人机以-v/etc/ssl:/etc/ssl:ro启动。 我知道无人机容器知道这个证书,因为它解决了由于oauth中的证书问题而无法登录的问题。 但是该构建在git获取中给出了一个错误,即“SSL证

我有一个本地gitlab节点和一个本地drone.io节点。 drone.io节点在ubuntu上运行。 gitlab节点使用自签名证书。 我已经以规范的ubuntu方式将证书添加到drone.io节点(cp cert.pem/usr/share/ca certificates/;更新ca证书)。 无人机以-v/etc/ssl:/etc/ssl:ro启动。 我知道无人机容器知道这个证书,因为它解决了由于oauth中的证书问题而无法登录的问题。 但是该构建在git获取中给出了一个错误,即“SSL证书问题:自签名证书”

我怀疑无人机启动了一些其他容器进行构建,而另一个容器没有证书。但我已经不知道发生了什么,也不知道如何在那里注入我的证书

启动无人机的脚本:

#!/bin/bash
set -x
docker kill drone
docker rm drone
docker run \
    --volume /var/lib/drone:/var/lib/drone \
    --volume /var/run/docker.sock:/var/run/docker.sock \
    --volume /etc/ssl:/etc/ssl:ro \
    --env-file /etc/drone/dronerc \
    --restart=always \
    --publish=80:8000 \
    --detach=true \
    --name=drone \
    drone/drone:0.4 \
    -debug
/etc/无人机/无人机:

# in gitlab, as an administrator, go to /admin/applications
# add a new application, the redirect uri being https://drone.machine/authorize
REMOTE_DRIVER=gitlab
REMOTE_CONFIG=https://ci-poc.devel.balabit?client_id=b88f2a6faefd8d9a05eddd82c8327bda6a59858fc7772753f4e2c0e6a7cd96e4&client_secret=966f752d39f211ef6b79a8c079d2ff1226f6ccd772a239efab4f4e4fb5de67a9
DATABASE_DRIVER=sqlite3
DATABASE_CONFIG=/var/lib/drone/drone.sqlite
HTTP_PROXY=http://proxy.balabit:3128/
HTTPS_PROXY=http://proxy.balabit:3128/
生成日志:

[info] Pulling image plugins/drone-git:latest
Drone Git Plugin built from 8be7aa9
$ git init
Initialized empty Git repository in /drone/src/gitlab.private/mag/devsec/.git/
$ git remote add origin https://gitlab.private/mag/devsec.git
$ git fetch --no-tags --depth=50 origin +refs/heads/master:
fatal: unable to access 'https://gitlab.private/mag/devsec.git/': SSL certificate problem: self signed certificate
[info] build failed (exit code 1)

解决方法是在.drone.yml中为克隆设置skip_verify

My.drone.yml如下所示,前两行是相关的

clone:
  skip_verify: true
build:
  image: magwas/edemotest:xslt
  commands:
    - ./bin/script

您可以设置以下环境变量,使主机的CA证书可供无人机运行程序使用:

-e DRONE_RUNNER_VOLUMES=/etc/ssl/certs/ca-certificates.crt:/etc/ssl/certs/ca-certificates.crt

这似乎不适用于gitlab。我已经尝试过了,但仍然遇到可怕的“SSL证书问题:无法获取本地颁发者证书”错误。gitlab插件似乎忽略了“skip_verify”,请参阅更多更新的示例和文档。跳过验证可以工作,但需要使用最新语法进行配置。