解析GOROOT、GOPATH、Go-Modules-三者的关系

一、GOROOT介绍

在安装完Golang语言的时候,所谓的安装路径其实就是你的GOROOT路径,也就是说GOROOT存放的Golang语言内建的程式库的所在位置,而通常你安装完后,你电脑的环境变数就会设好GOROOT路径,当你开发Golang程式的时候,当你import内建的程式库的时候,并不需要额外安装,而当程式运行后,预设也会先去GOROOT路径下寻找相对应的程式库来运行。

1、查看Glang环境变量

go env

环境变量

env中有些是我已经修改过的,通常如果你是初次安装Golang语言并且没做什么环境变数设定的话,GOROOT设定路径就是你当初安装Golang语言的路径,而GOPATH通常预设会是使用者目录下的go资料夹。

2、使用 go run 执行某个文件

package main

import (
	"fmt"
)

func main() {
	fmt.Println("hello world")
}

然后再执行以下指令:

go run main.go

就会成功输出hello worldgo run其实会帮你将程式码进行编译并产生执行档,而编译档跟执行档事实上是存在一个暂存资料夹里面,当运行完此程式就会自动删除。该指令可以想成类似直译的方式运行,而不需要做其他任何环境设定,即可运行。

3、引用第三方套件

package main

import (
	"github.com/gin-gonic/gin"
)

func main() {
	router := gin.Default()
	router.Run()
}

import了一个github.com/gin-gonic/gin套件,这个是别人开发的Web Framework套件,是不存在于官方程式库的,而是放在GitHub上的第三方套件。

  • 当执行Golang程式码,当需要存取套件时,会先去GOROOT路径下的src资料夹找同等于我们在程式码中import的路径下去找有没有gin这个资料夹,而这资料夹里面就是包含了所有有关于该套件的程式库。
  • 如果在GOROOT路径下没有找到,则会往GOPATH路径下的src资料夹找同等于我们在程式码中import的路径下去找有没有gin这个资料夹。

所以只要GOROOTGOPATH路径下都没有找到该套件的话,就无法执行该程式码。

二、GOPATH介绍

根据上面GOROOT的介绍,我们可以知道官方的程式库所在位置就是在GOROOT里面,而GOPATH就是专门存放第三方套件以供我们程式码的需要。那通常开发Golang的话,通常会在重新设定GOPATH的位置。

1、GOPATH目录

bin
pkg
src

依照Golang语言的惯例(强制),GOPATH是指src路径的上一层,我们要在GOPATH路径下主动新增src资料夹,所谓src就是代表source code的意思,也就是放我们开发Golang程式码的相关专案的原始码。

2、GOPATH的缺点

第三方套件只要不是官方程式库,都需要放置在GOPATH/src的路径下才可以使用。

go get最常用在当我们想用别人公开在GitHub上的套件,可以帮我们从网路上clone到GOPATH/src里面。虽然这样很方便,但是你会发现GOPATH/src下的程式码会很复杂,除了有你自己开发的专案资料夹,也包含其他第三方程式库的专案资料夹。

再来,如果你开发的专案采用第三方套件是不同版本怎么办?以往的解决方法是要设定多组不同的GOPATH。虽然社群也有开发相对应的package manager,如VendorDep来解决该问题,但毕竟不是官方主导的。

三、Go Modules的诞生

为了解决不被GOPATH的问题,因此官方在1.11开始推出了Go Modules的功能。Go Modules解决方式很像是Java看到Maven的做法,将第三方程式库储存在本地的空间,并且给程式去引用。

1、设定GO111MODULE环境变数

总共可以三种不同的值:

  • auto

默认值,go命令会根据当前目录来决定是否启用modules功能。需要满足两种情形:
该专案目录不在GOPATH/src/
当前或上一层目录存在go.mod档案

解析GOROOT、GOPATH、Go-Modules-三者的关系

扫一扫手机访问