如此,用dep获取私有库

前端之家收集整理的这篇文章主要介绍了如此,用dep获取私有库前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

如此,用dep获取私有库

介绍

dep是一个依赖管理工具。它需要1.9或更新的Golang版本才能编译@H_301_9@

dep已经能够在生产环节安全使用,但还在官方的试验阶段,也就是还不在go tool中。但我想是迟早的事 :=)@H_301_9@

指南和参考资料,请参阅文档@H_301_9@

获取私有库

我们常用的git方式有两种,第一种是通过ssh,第二种是https@H_301_9@

本文中我们以gitlab.com为案例,创建一个private的私有仓库@H_301_9@

通过ssh方式

首先我们需要在本机上生成ssh-key,若没有生成过可右拐传送门@H_301_9@

得到需要使用的ssh-key后,我们打开我们的gitlab.com,复制粘贴入我们的Settings -> SSH Keys中@H_301_9@

@H_301_9@

添加成功后,我们直接在Gopkg.toml里配置好我们的参数@H_301_9@

[[constraint]]
  branch = "master"
  name = "gitlab.com/eddycjy/test"
  source = "git@gitlab.com:EDDYCJY/test.git"

在拉取资源前,要注意假设你是第一次用该ssh-key拉取,需要先手动用git clone拉取一遍,同意ECDSA key fingerprint:@H_301_9@

$ git clone git@gitlab.com:EDDYCJY/test.git
Cloning into 'test'...
The authenticity of host 'gitlab.com (52.167.219.168)' can't be established.
ECDSA key fingerprint is xxxxxxxxxxxxx.
Are you sure you want to continue connecting (yes/no)? yes
...

接下来,我们在项目下直接执行dep ensure就可以拉取下来了!@H_301_9@

问题

  1. 假设你是第一次,又没有执行上面那一步(ECDSA key fingerprint),会一直卡住
  2. 正确的反馈应当是执行完命令后没有错误,但如果出现该错误提示,那说明该存储仓库没有被纳入dep中(例:gitee
$ dep ensure

The following issues were found in Gopkg.toml:

unable to deduce repository and source type for "xxxx": unable to read Metadata: go-import Metadata not found

ProjectRoot name validation Failed

通过https方式

我们直接在Gopkg.toml里配置好我们的参数@H_301_9@

[[constraint]]
  branch = "master"
  name = "gitlab.com/eddycjy/test"
  source = "https://{username}:{password}@gitlab.com"

主要是修改source的配置项,username填写在gitlab用户名password为密码@H_301_9@

最后回到项目下执行dep ensure拉取资源就可以了@H_301_9@

最后

dep目前还是官方试验阶段,还可能存在变数@H_301_9@

请务必以sf上的原文为准,如果dep新版本有变动,会随着修改@H_301_9@

猜你在找的设计模式相关文章