做6.824 实验的过程中想要跑测试,发现go test -run 2A
时 出现cannot find main module
问题,测试跑不起来。
这个原因是从GO1.11 版本开始引入了go.mod
文件来对项目中的go源码的编译相关的内容进行管理,经常使用GO的同学可能深受go get
或者GOPATH
的配置之苦,这个时候引入了go.mod
文件,就能将这一些配置释放出来,只需要将项目需要的依赖以及项目的路径放在go.mod
中,交给GO本身来做即可。
这个时候一些老的GO项目本身没有配置go.mod
文件(比如mit6.824 lab
的源代码没有配置),所以编译的时候会出现这样的问题。
如果不会配置go.mod
文件,且项目中不需要太多的配置,只想编译运行,可以直接关闭GO编译对这个文件的依赖,通过设置GO环境变量GO111MODULE
为off
即可,export GO111MODULE=off
。
如果想要试用这个文件的功能,可以参考etcd
的go.mod
形态。
module go.etcd.io/etcd/v3 /*指定根目录*/go 1.16replace ( /*取代当前项目中的依赖包,即用左边的包取代右边的包*/go.etcd.io/etcd/api/v3 => ./apigo.etcd.io/etcd/client/pkg/v3 => ./client/pkggo.etcd.io/etcd/client/v2 => ./client/v2go.etcd.io/etcd/client/v3 => ./client/v3go.etcd.io/etcd/etcdctl/v3 => ./etcdctlgo.etcd.io/etcd/pkg/v3 => ./pkggo.etcd.io/etcd/raft/v3 => ./raftgo.etcd.io/etcd/server/v3 => ./servergo.etcd.io/etcd/tests/v3 => ./tests
)require ( /*依赖的代码包及其版本*/github.com/bgentry/speakeasy v0.1.0github.com/dustin/go-humanize v1.0.0github.com/mattn/go-runewidth v0.0.9 // indirectgithub.com/spf13/cobra v1.1.1go.etcd.io/bbolt v1.3.6-0.20210426205525-9c92be978ae0go.etcd.io/etcd/api/v3 v3.5.0-alpha.0go.etcd.io/etcd/client/pkg/v3 v3.5.0-alpha.0go.etcd.io/etcd/client/v2 v2.305.0-alpha.0go.etcd.io/etcd/client/v3 v3.5.0-alpha.0go.etcd.io/etcd/pkg/v3 v3.5.0-alpha.0go.etcd.io/etcd/raft/v3 v3.5.0-alpha.0go.etcd.io/etcd/server/v3 v3.5.0-alpha.0go.etcd.io/etcd/tests/v3 v3.5.0-alpha.0go.uber.org/zap v1.16.1-0.20210329175301-c23abee72d19golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3bagoogle.golang.org/grpc v1.36.1gopkg.in/cheggaaa/pb.v1 v1.0.28
)
自定义日志域Custom Logging Fields 下面的字段描述了ATS支持的自定义日志域 {HTTP header field name}cqh {HTTP header field name}pqh {HTTP header field name}psh {HTTP header field name}ssh...