草庐IT

go.mod 在修订时有 post-v0 模块路径 "git.example.com/owner/repo/v3"...?

在更新go.mod以具有/v3后缀(https://github.com/golang/go/wiki/Modules#releasing-modules-v2-or-higher)之前,我的同事推送了一个标签v3.0.1。我更新了模块路径(go.mod)和所有导入路径(*.go)来修复它,标记为v3.0.2。现在的问题是:goget-vgit.example.com/owner/repo@v3.0.2go:findinggit.example.com/owner/repov3.0.2go:git.example.com/owner/repo@v0.0.0-20190722053407

git - 如何在不终止连接的情况下更新 docker web 应用程序?

我有一个docker-compose.yml,它有两个服务:一个数据库和我的Go应用程序。我的CI/CD管道调用托管此docker容器的服务器并运行此bash脚本:gitfetch&>/dev/nulldiffs=$(gitdiffmasterorigin/master)if[!-z"$diffs"]thenecho"PullingcodefromGitHub..."gitcheckoutmastergitpulloriginmaster#updateserverdocker-composeup--build-d#killallunuseddockercontainersdockers

go - 如何使用 go-git 查找 sha of origin/master?

我正在尝试使用go-git查找origin/master的SHA1,在我已经完成了与gitfetch--all等效的操作之后。然而,go-git似乎不支持:gitls-remotegit@github.com:StevenACoffman/toolbox.gitgitrev-parseorigin/master有没有其他方法可以使用go-git确定origin/master的SHA1? 最佳答案 糟糕!支持gitrev-parse!使用./main.go$PWDorigin/master执行以下命令:///usr/bin/envgo

git - 获取特定分支的标签

使用go-git:有没有办法只获取特定分支的(轻量级和带注释的)标签?因为我主要对master分支的标签感兴趣,像gittag--merged这样的东西也足够了。使用像Tags()这样的基本go-git方法似乎是不可能的...... 最佳答案 不完全是一个简短的解决方案,但以下代码通过以下方式实现了目标:读取整个分支的提交哈希值。读取存储库的所有标签。检查并只打印散列在分支中的标签。注意:尚未尝试使用带注释的标签。但应该很接近。packagemainimport("log""github.com/src-d/go-billy/mem

git - 处理 Go Git 存储库及其非代码资源

我是Go的新手,我正在努力寻找处理Git存储库的最佳方法。目前我使用的是Go官方推荐的目录结构,但是我觉得它有很多坑。有点像$GOPATHbinnon-important-stuffpkgnon-important-stuffsrcgithub.comusernamereponame情况是我有很多非代码资源,比如默认设置文件、html模板和图像……但我觉得把它放在“src/github.com/username/reponame”中似乎有点奇怪目录(因为第一个“src”部分)。这个问题最常见的解决方案是什么?我现在面临的另一个问题是,我不知道最常用的“make”工具来构建带有外部资源(

logging - 在 log.SetOutput(ioutil.Discard) 之后延迟 log.SetOutput(os.Stdout)

在go-nsq库(https://github.com/bitly/go-nsq/blob/master/writer_test.go#L38)中,我找到了以下代码:log.SetOutput(ioutil.Discard)deferlog.SetOutput(os.Stdout)为什么作者在丢弃日志后将日志记录延迟到标准输出? 最佳答案 log.SetOutput(ioutil.Discard)语句更改标准记录器输出目的地。deferlog.SetOutput(os.Stdout)语句尝试在函数结束时将输出目标重置回其初始值。但是

logging - Golang go-workers自定义日志记录中间件?

我正在构建一个Golang实现Sidekiq的应用程序-兼容jrallison/go-workers工作队列和围绕Sirupsen/logrus的自定义日志记录包装器用于编码的JSON日志。现在,我的所有应用程序(除了go-workers到目前为止)都在中心位置使用我的记录器包装器,以确保其输出的100%与JSON兼容。请注意,第1行和第2行是来自中央记录器的正确JSON,但是当go-workers初始化时,我们看到第3行来自错误的纯文本记录器。{"db":{"Mapper":{}},"instance_id":"1","level":"info","msg":"Db:Connecte

git - 如何在 git2go (libgit2) 中列出包含给定提交的分支?

给定一个特定的引用(在本例中是一个标签),你如何列出包含该提交的分支git2go?类似于gitbranch--contains. 最佳答案 这里的问题,从图的角度来看是“我怎么知道A是否是B的祖先?”(对于您想成为B的每个分支重复几次)。回答这个问题的唯一方法是从B开始沿着历史图走下去,然后检查是否找到A。您可以通过几种方式做到这一点,但最有效的通常是将问题简化为等同的“A是A和B的merge基础吗?”。您可以通过Repository.MergeBase()在git2go中询问这个问题。这将返回您提供的两个提交之间的最佳merge基

git - Gig2go : unpacking the sent packfile failed on the remote

我为此苦苦挣扎。我正在尝试使用以下代码将更改推送到存储库://Getremoteremote,err:=repo.Remotes.Lookup("origin")iferr!=nil{remote,err=repo.Remotes.Create("origin",repo.Path())iferr!=nil{returnerr}}//Getthebranchbranch,err:=repo.Branch()iferr!=nil{returnerr}//GetthenamebranchName,err:=branch.Name()iferr!=nil{returnerr}iferr:=r

logging - Go:文件错误记录中的新行

我比较陌生,希望将错误注销到文本文件中。目前我使用://Loggingf,err:=os.OpenFile("pgdump_errorlog.txt",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{log.Fatalf("erroropeningfile:%v",err)}deferf.Close()log.SetOutput(f)//...(lateron)iferr!=nil{log.Fatal(err)}这工作正常,减去了错误不会产生新行并且只是附加到第一行末尾的事实。有没有办法让错误输出在附加之前创建一个新行?我试过:ife