GoModule

GOPATH
最早的就是GOPATH构建模式,
go get下载的包都在path中的src目录下
src目录是源代码存放目录。

package main

import (
	"net/http"

	"github.com/gorilla/mux"
)

func main() {
	r := mux.NewRouter()
	r.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) {
		w.Write([]byte("Hello, world!"))
	}).Methods("GET")
	http.ListenAndServe(":8080", r)
}

上面的例子中,因为还没有下载github这个,所以导致报错,
因为从我们默认的GOPATH下找不到这个依赖的包,所以编译失败。
但是go get就可以下载依赖包,但是此时下载是最新的,如果后续更新引入了不兼容代码,那么将会无法编译成功。

Go Vendor

Go Module
第一步,使用go mod int创建go.mod文件,将当前项目变成一个Go Module;

第二步,通过 go mod tidy 命令自动更新当前第三方依赖

第三步,执行go build编译,构建可执行程序

module test

go 1.23.0

require github.com/gorilla/mux v1.8.1 // indirect

刚才的go get一下github地址,就可以自动更新go module到go.mod

效果:
在这里插入图片描述
在go.mod文件中,我们看到require中依赖的版本号是v1.8.1。
其实,在Go Module模式下,语义版本号主要由三部分组成,
主版本号(major)、次版本号(minor)和补丁版本号(patch),
例如上面的版本号v1.8.1,

主版本号就是1, 次版本号就是8, 补丁版本号就是1。

主版本号不同的两个版本是相互不兼容的,
而且在主版本号相同的情况下,
次版本号大都是向前兼容次版本号小的版本的,
补丁版本也不影响兼容性。

所以:如果某一天mux包发布了v2.0.0版本,那么这时候主版本就是2,已经与v1.8.1和v1.7.1的主版本号不同了,那么v2.0.0与v1.8.1和v1.7.1就是不兼容的包版本。

Go Module常见操作
1.添加第三方依赖包:
为了操作redis,发送kafka消息等等需要导入第三方依赖包。

package main

import (
  "net/http"

  "github.com/google/uuid"
  "github.com/gorilla/mux"
)

func main() {
  r := mux.NewRouter()
  r.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) {
    w.Write([]byte(uuid.NewString()))
  }).Methods("GET")
  http.ListenAndServe(":8080", r)
}

上述代码中,我们还没有下载uuid这个包
所以我们要go get一下这个包,如下所示。(也可以go mod tidy,而且go mod tidy效率更加高)
在这里插入图片描述2.升降级第三方依赖包:
在项目开发中,如果升级了某个包的版本且新版本的包存在一些问题,比如对服务的整体性能产生了影响,我们可以手动的将它降级为之前发布的某个兼容版本。

go list -m -versions github.com/google/uuid//查看包有哪些版本

降级的话:

go get github.com/google/uuid@v1.5.0

在这里插入图片描述降级成功如上图所示。
除了用go get来降级,也可以用go mod tidy来降级依赖包
但是首先要使用go mod edit明确告知依赖的版本

$ go mod edit -require=github.com/google/uuid@v1.4.0
$ go mod tidy

移除第三方依赖包
直接使用go mod tidy自动分析不需要的就可以直接移除。

面试题:

你知道Go构建模式演进过程吗?
说下GOPATH的构建原理?说下GO Vendor的构建原理?
GOPATH有什么缺点?Go Module有什么缺点?
如果导入的第三方依赖包版本不兼容该怎么处理?
Go最小依赖版本选择你知道吗?说下原理?
你觉得当前的Go Module构建模式有什么缺点?该如何改进?

要启用Go语言的模块支持(即gomodule模式),你需要按照以下步骤操作: 1. 在项目根目录下创建一个名为`go.mod`的文件。这个文件是Go模块系统的标记,它声明了模块的路径,该路径随后会被用作导入包的前缀。你不需要在这个文件中添加任何代码,只需要创建文件即可。 2. 确保你的环境变量`GO111MODULE`设置正确。Go语言提供了三种环境变量模式来控制模块行为: - `GO111MODULE=on`:启用模块支持,即使在GOPATH之外也会使用模块。 - `GO111MODULE=off`:禁用模块支持,即使在有go.mod文件的情况下,也会像以前一样使用GOPATH。 - `GO111MODULE=auto`:默认值,当项目在GOPATH之外并且存在go.mod文件时,启用模块支持。 通常,你不需要修改这个环境变量,除非你需要强制启用或禁用模块系统。 3. 在你的代码中,使用模块路径作为包导入路径的前缀。例如,如果你的模块路径是`github.com/username/repo`,那么你应该使用`import "github.com/username/repo/modulename"`来导入模块内的包。 4. 运行`go mod init`命令初始化模块。如果你还没有创建`go.mod`文件,这个命令将会为你创建,并且设置模块的名称。这个名称通常基于当前目录的路径,或者你可以在命令后指定一个模块路径。 例如,如果你在命令行中位于项目根目录下,你可以执行如下命令来初始化模块: ```shell go mod init example.com/myproject ``` 这将会创建一个名为`go.mod`的文件,并在其中声明模块的路径。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MatsumotoChrikk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值