go module 的本地仓库依赖解决方案(Multi-Module Workspaces)多 module 工作区模式 简介
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
背景
go
中的项目引用库一般都是放在 git
仓库中的go.mod
中通过 require
来进行引用
require github.com/common
但是当同一个项目由多个项目开发人员共同开发如统一的 common
仓库存放一些常用的函数而且这个仓库经常会进行改动这时使用这种引用远端的仓库方式就不适合了。
module
可以使用本地依赖在 go.mod
文件中使用 replace
来做替换如下
replace github.com/common => ../common
这样就可以直接修改本地代码进行调试但是这也存在问题并不能保证所有人的本地环境都一样如果不小心将修改提交到 git
仓库就会影响其他人如果能统一项目的结构那使用 replace
也是没有什么问题的在 go1.18
之前就是这么做的也不是不能接受。
但是 go1.18
后遇到这类问题我们可以有更好的使用 mod
的方法了go
团队提供了一个新特性 Multi-Module Workspaces
多 module
工作区模式。
使用
其原理和 replace
相似也是通过依赖本地环境模块来修改 mod
的指向。
1. 创建并初始化工作区
$ mkdir workspace #创建工作区目录
$ cd workspace
$ go work init #初始化work工作区
至此我们可以看到工作区中生成了 go.work
文件文件中只有一行内容
go 1.18
2. 创建 go
模块
如果已有 go
模块可以直接跳过此步。
$ mkdir wd #在刚刚创建的 workspace 目录下创建新的目录
$ cd wd
$ go mod init wd
$ vim wd.go # 新建 wd.go 文件
wd.go
内容如下
package wd
const Version = "1.0"
这里只给声明一个 Version
常量用于演示。
$ cd .. && mkdir test #在刚刚创建的 workspace 目录下创建新的目录
$ cd test
$ go mod init test
$ vim main.go # 新建 main.go 文件
main.go
内容如下
package main
import "wd"
func main() {
println(wd.Version)
}
引用之前的 wd
模块并输出其 Version
值。
3. 向工作区中添加模块
执行完上述步骤后当前的目录结构为
- workspace
- test
- go.mod
- main.go
- wd
- go.mod
- wd.go
- go.work
向工作区中添加模块可以指向相对路径或绝对路径。在 workspace
工作区目录下执行
$ go work use ./test ./wd
执行完后go.work
文件内容变更如下
go 1.18
use (
./test
./workMod
)
注意windows
使用绝对路径的时候go.work
文件中 use
需要带上 “引号”
go 1.18
use (
"C:/workspace/test"
./wd
)
4. 测试
在 workspace
工作区目录下执行 go run ./test
可以看到能够输出 wd
模块的 Version
1.0
go.work 命令
支持三个指令
- go: 声明
go
版本号主要用于后续新语义的版本控制。 - use: 声明应用所依赖模块的具体文件路径路径可以是绝对路径或相对路径。
- replace: 声明替换某个模块依赖的导入路径优先级高级 go.mod 中的 replace 指令。
若要禁用工作区可以使用 -workfile=off
指令
go run -workfile=off ./test
go build -workfile=off ./test
总结
go
在 1.18
新推出的 multi-module workspaces
模式主要就是解决本地开发依赖问题用于解决平常开发时的痛点问题
- 依赖本地
replace module
。 - 依赖本地未发布的
module
。
- 设置了工作区后所有的配置都会以工作区的配置为最高优先级。
go.work
文件不需要上传到git
仓库本地使用即可。go.work
文件使用绝对路径不生效时需要在引用模块上加上引号use("C:/workspace/test")
。