Go Modules介绍

为了解决Go包管理的问题,Go从1.11开始加入了Go Modules这一新特性。让包的依赖和版本管理更加容易。golang

modulemodulego.modgo.modmoduleimportpathmodule
Go 1.11须要设置GO111MODULE来开启module功能 
GO111MODULE=on,会开启使用module
GO111MODULE=auto默认值,会根据当前目前来决定是否开启module。若是当前目录在``GOPATH/src``以外且当前目录有``go.mod``文件或当前文件在包含go.mod文件的目录下面
从Go 1.13开始module被默认开启

建立一个module

GOPATH/srchellohello.go
package hello

func Hello() string {
    return "Hello, world."
}
hello_test.go
package hello

import "testing"

func TestHello(t *testing.T) {
    want := "Hello, world."
    if got := Hello(); got != want {
        t.Errorf("Hello() = %q, want %q", got, want)
    }
}

运行go test命令,这个时候返回:get

PS D:\Code\hello> go test
PASS
ok      _/D_/Code/hello 0.176s
D:\Code\helloGOPATH/src_/D_/Code/hello
go mod init 
go mod init example.com/hello
go: creating new go.mod: module example.com/hello

go test
PASS
ok      example.com/hello       0.177s
ok example.com/hello 0.177sgo.mod
module example.com/hello

go 1.14
modmoduleimport pathpath

添加外部依赖

在hello.go文件中导入一个外部的包:io

package hello

import "rsc.io/quote"

func Hello() string {
    return quote.Hello()
}

运行单测:

go: finding module for package rsc.io/quote
go: found rsc.io/quote in rsc.io/quote v1.5.2
--- FAIL: TestHello (0.00s)
    hello_test.go:8: Hello() = "你好,世界。", want "Hello, world."
PASS
ok      example.com/hello       0.177s
go.mod
module example.com/hello

go 1.14

require rsc.io/quote v1.5.2
rsc.io/quotego.mod
PASS
ok      example.com/hello       0.177s
gorsc.io/quotego list -m all 
example.com/hello
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c
rsc.io/quote v1.5.2
rsc.io/sampler v1.3.0
rsc.io/quotego.modgo.sum
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c h1:qgOY6WgZOaTkIIMiVjBQcw93ERBE4m30iBm00nkL0i8=
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
rsc.io/quote v1.5.2 h1:w5fcysjrx7yqtD/aO+QwRjYZOKnaM9Uh2b40tElTs3Y=
rsc.io/quote v1.5.2/go.mod h1:LzX7hefJvL54yjefDEDHNONDjII0t9xZLPXsUe+TKr0=
rsc.io/sampler v1.3.0 h1:7uVkIFmeBqHfdjD+gZwtXXI+RODJ2Wc4O7MPEh/QiW4=
rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA=

后面增长了每一个外部依赖内容的hash值,go经过这些hash值去验证你下载依赖的正确性。

升级版本

go list -m allgolang.org/x/text v0.0.0-20170915032832-14c0d48ead0cv0.0.0-20170915032832-14c0d48ead0c
go get golang.org/x/text
go: golang.org/x/text upgrade => v0.3.3
go: downloading golang.org/x/text v0.3.3

go test
PASS
ok      example.com/hello       0.199s
go.mod
module example.com/hello

go 1.14

require (
	golang.org/x/text v0.3.3 // indirect
	rsc.io/quote v1.5.2
)
golang.org/x/text v0.3.3 // indirectv0.3.3
go list -m all 
example.com/hello
golang.org/x/text v0.3.3
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e
rsc.io/quote v1.5.2
rsc.io/sampler v1.3.0

移除没有使用的依赖

go mod tidy 

下载依赖到当前目录

go mod vendor

老项目的迁移

GOPATH/src
go mod init xxx

go build

须要注意的是迁移项目可能会出现包冲突的问题,会报相似

cannot load xxxx: ambiguous import: found xxxx in multiple modules:

这样的错误,这时可能须要再go.mod中手动指定这个包的版本号