The use of go module is very simple
-
Initialize go.mod
go mod init
Copy after login -
Organize dependency packages
go mod tidy
Copy after login -
If you want to cache to the vendor directory
go mod vendor
Copy after login
The dependencies will be automatically resolved after executing the command.
But, if we develop the package locally and do not have a remote warehouse, how to solve the local package dependency problem?
Use replace to replace the remote package with the local package service
Fortunately, go module provides another solution, replace. How to use this replace?
Let's take a look at a basic mod file first
module GoRoomDemo go 1.12 require ( github.com/gin-gonic/gin v1.3.0 github.com/gohouse/goroom v0.0.0-20190327052827-9ab674039336 github.com/golang/protobuf v1.3.1 // indirect github.com/gomodule/redigo v2.0.0+incompatible github.com/mattn/go-sqlite3 v1.10.0 github.com/stretchr/testify v1.3.0 // indirect golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53 // indirect )
This is a simpleGoRoom
The dependency package of the framework, if I want to use the local goroom
, I only need to use replace
module GoRoomDemo go 1.12 require ( github.com/gin-gonic/gin v1.3.0 github.com/gohouse/goroom v0.0.0-20190327052827-9ab674039336 github.com/golang/protobuf v1.3.1 // indirect github.com/gomodule/redigo v2.0.0+incompatible github.com/mattn/go-sqlite3 v1.10.0 github.com/stretchr/testify v1.3.0 // indirect golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53 // indirect ) replace github.com/gohouse/goroom => /path/to/go/src/github.com/gohouse/goroom
Herepath/to/go/src/github .com/gohouse/goroom
is the local package path
In this way, we can happily use the local directory.