- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
在 Go 中,如果您引用另一个包,例如GitHub 上的一些东西,然后 Go 总是从 master
分支获取最新版本。虽然这对开发很有帮助,但我想这是生产中的一个问题:这样构建就无法重现。
那么,在 Go 中修复依赖版本的正确方法是什么,以及如何有效地处理这个问题?
一位 friend 向我指出了 godep ,这看起来不错,但我想知道有哪些替代方案,以及 godep 的优点/缺点是什么?
最佳答案
使用 Go 1.11 更新 2018
Dependencies should now be referenced with modules (源自 the vgo project ):
Go 1.11 adds preliminary support for a new concept called “modules,” an alternative to
GOPATH
with integrated support for versioning and package distribution.
Using modules, developers are no longer confined to working insideGOPATH
, version dependency information is explicit yet lightweight, and builds are more reliable and reproducible.
参见 Defining a module 。 (和 original design proposal )
2015 年 6 月更新:Go 1.5 首次支持 vendoring!
参见 c/10923/ :
When
GO15VENDOREXPERIMENT=1
is in the environment, this CL changes the resolution of import paths according to the Go 1.5 vendor proposal:
- If there is a source directory
d/vendor
, then, when compiling a source file within the subtree rooted atd
,import "p"
is interpreted asimport "d/vendor/p"
if that exists.- When there are multiple possible resolutions, the most specific (longest) path wins.
- The short form must always be used: no import path can contain “
/vendor/
” explicitly.- Import comments are ignored in vendored packages.
2015 年 3 月更新:go 团队正在考虑定义一个集成到语言中的 go 依赖管理系统:争论是 in this thread .
We think it’s time to start addressing the dependency & vendoring issue, especially before too many conflicting tools arise and fragment best practices in the Go ecosystem, unnecessarily complicating tooling. It would be nice if the community could converge on a standard way to vendor.
Our proposal is that the Go project,
- officially recommends vendoring into an “internal” directory with import rewriting (not
GOPATH
modifications) as the canonical way to pin dependencies.- defines a common config file format for dependencies & vendoring
- makes no code changes to
cmd/go
in Go 1.5. External tools such as “godep
” or “nut
” will implement 1) and 2). We can reevaluate including such a tool in Go 1.6+.
godep 的一个可能缺点是你不能再直接使用“go build”或“go test”。
您需要在这些命令之前加上 godep
(或键入 godep save
)。
另一种选择是 glide ,它仍然与经典的 go 命令兼容。
- Manage project-specific GOPATHs
- Ease dependency management
- Support versioning packages
- Support aliasing packages (e.g. for working with github forks)
- Remove the need for "vendoring" or munging import statements
- Work with all of the go tools
更一般地说,文章“Know your guarantees, Go edition”很有趣:
It’s also a deliberate choice, where the Go authors chose not to implement a feature when they felt that the trade-offs were no good.
One low-level reason they made this choice is to avoid slow compilation and bloated binaries (which are two sides of the same coin).
Remember, packages depend on other packages. SoFoo
might depend onBar
2.1.Foo
might also depend onBaz
which in turn depends onBar
1.9, and on down the tree. So that would mean compiling and linking several copies of nearly identical code.Depending on several versions of the same package also means knowing which version one is calling, whereby the dependency mess seeps into your source code.
Which leads us to the high-level reasoning behind the Go platform punting on this feature: they did not have a logical solution they considered acceptable. It’s not that they don’t understand the problem; it’s that, at the moment, there is not a solution they like. So they choose no feature over over a regressive one.
关于go - 在 Go 中处理依赖关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27184549/
我正在使用 go 图表库 https://github.com/wcharczuk/go-chart制作条形图。我面临的问题是标签值很长,我想将文本旋转 45 度以显示完整文本 我喜欢显示的日期格式是
我在构建一个非常简单的通过 cgo 调用 c 代码的 go 程序时遇到了问题。我的设置: $: echo $GOPATH /go $: pwd /go/src/main $: ls ctest.c
没有 C 的背景,只有 Go 的“初学者”经验,我正在尝试弄清楚 main.go 是实际需要的还是只是一个约定。 我想创建一个简单的网络 API,但有人可以为我澄清一下吗? 最佳答案 main.go
我read从 Go 1.4 开始,Go 运行时是用 Go 本身编写的(而不是用 C)。 这怎么可能?如果 Go 程序在运行时之上运行,并且运行时是 Go 程序,那么运行时是否在自身之上运行? 最佳答案
这是“Go 之旅”中的代码示例 Range and Close : package main import ( "fmt" ) func fibonacci(n int, c chan int
给定以下 go.mod 文件: module foo go 1.12 require ( github.com/bar/baz v1.0.0 github.com/rat/cat v1
我有一个 CI/CD 管道,它需要跨平台并与几个不同的管理程序一起工作。为了不必更改 Windows 和 Linux 的构建任务,我认为 Go 将是编写一次代码并在任何地方运行的好方法。然而,考虑到
我有一个 Dockerfile,用于使用 go build 编译 Go 应用程序。我进行了研究,确实建议将 go build 用于生产。 但是我找不到正确的答案来解释为什么。 我了解 go run 创
我尝试在命令提示符#Go lang 中运行该程序-但是当我键入运行“go run hello.go”命令时,我开始了 CreateFile hello.go:The system cannot fin
我正在使用“Go 编程语言”一书学习 Go。第一章介绍os.Open用于读取文件的模块。我尝试打开如下所示的 go 文件。 f, err = os.Open("helloworld.go") 我收
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 2年前关闭。 Improve this
为了解决我对 goroutine 的一些误解,我去了 Go 操场跑了 this code : package main import ( "fmt" ) func other(done cha
这个问题在这里已经有了答案: Evaluate/Execute Golang code/expressions like js' eval() (5 个回答) 1年前关闭。 对于任何 go 程序,我想
这是我基本上试图从路径打印基准的代码。 这意味着,如果用户输入“/some/random/path.java”,则输出将为“path”。同样,如果用户arg为“/another/myapp.c”,则输
$ go version 1.13.3 我的文件夹结构如下: GOPATH +---src +--- my-api-server +--- my-auth-server
这个问题在这里已经有了答案: How to embed file for later parsing execution use (4 个答案) What's the best way to bun
我觉得这有点奇怪,为什么这段代码不起作用? package main import "fmt" func main() { var i, j int = 1, 2 k
go编译器执行完如下命令后的可执行文件存放在哪里? $> go run file.go 最佳答案 在 /tmp 文件夹中,如果您使用的是 unix 机器。 如果您使用的是 Windows,则在 \Us
我目前正在开始使用 Go,并且已经深入研究了有关包命名和工作区文件夹结构的注意事项。 不过,我不太确定如何根据 Go 范式正确组织我的代码。 这是我当前的结构示例,它位于 $GOPATH/src 中:
假设我有一个接受用户输入的 Lua 程序,而该输入恰好是有效的 Lua 源代码。这是在程序仍在运行时进行清理、编译和执行的。 Go 是否(或将)实现这样的事情? 最佳答案 我认为以下两个项目之间有足够
我是一名优秀的程序员,十分优秀!