电子说
Go 源代码的安装目录,Mac
和 Windows
安装时会自动配置好,Linux
一般在 /usr/local/go
目录。
# 查看 $GOROOT 目录
$ echo $GOROOT
/usr/local/bin
# 设置 $GOROOT 目录
$ export GOROOT=/usr/local/bin
# 增加 go 相关命令到 PATH
$ export PATH=$PATH:/usr/local/go/bin
简单来说,就是存放 Go 第三方库的源代码以及构建后可执行程序的目录,建议设置为独立的目录并且不要存放其他文件。
# 查看 $GOPATH 目录
$ echo $GOPATH
/home/codes/go
# 设置 $GOPATH 目录
$ export GOPATH=/home/codes/go
安装包的下载代理地址,直接使用 七牛云
提供的代理地址 ,速度非常快!
# 查看 $GOPROXY 代理地址
$ echo $GOPROXY
https://goproxy.cn
# 设置 $GOPROXY 目录
$ export GOPROXY=https://goproxy.cn
是否开启了 gomod
, 必须开启才可以使用 Go Module
。
# 查看 $GO111MODULE 模块开启情况
$ echo $GO111MODULE
on
# 设置 $GOPROXY 目录
$ export GO111MODULE="on"
建议将刚才的配置写入 ~/.bashrc
或者 ~/.zshrc
文件,永久有效。 到这里,我们第一步设置基础环境变量的工作就完成了,可以验证一下设置是否成功:
$ go env | grep -i -E "root|path|goproxy|module"
GO111MODULE="on"
GOPATH="/home/codes/go"
GOPROXY="https://goproxy.cn"
GOROOT="/usr/local/go"
通过输出结果可以看到,刚才的配置已经全部完成。
env
命令除了查看环境变量外,同样可以设置环境变量。
# 通过 go env 命令设置代理环境变量
$ go env -w GOPROXY=https://goproxy.cn,direct
Go 从 1.12 版本开始,默认支持 Go Modules
, 从此彻底告别配置 GOPATH
以及包下载及依赖导致的各种奇葩问题。
这里假设项目名称为 HelloWorld
。
/home/codes/projects/HelloWorld
/home/codes/projects/HelloWorld
目录go mod init helloworld
# 输出如下
go: creating new go.mod: module helloworld
go: to add module requirements and sums:
go mod tidy
go.mod
文件,其中内容如下$ cat go.mod
module helloworld
go 1.19 # 版本号可能和你的不一样
Go 的包名定义非常简单,就是一个普通的 URL (以域名打头),可以是主流的代码仓库地址,也可以是自己搭建的代码仓库。下面的例子统一以 Github 演示。
# 语法规则: 其中版本号可以是 git 分支或 tag
go get 包名@版本号
# 例: go get github.com/spf13/cast@v1.4.1
spf13/cast
是一个数据类型转换包,可以非常简单地对常见数据类型互相转换,并且不会引发 panic
。
$ go get github.com/spf13/cast@v1.4.1
# 输出如下
go: added github.com/spf13/cast v1.4.1
go.mod
文件,内容如下:module helloworld
go 1.19
require github.com/spf13/cast v1.4.1 // indirect
go.mod
旁边多了一个 go.sum
文件,内容如下:github.com/davecgh/go-spew
...
...
github.com/stretchr/testify
将如下代码写入文件 main.go
package main
import (
"fmt"
"github.com/spf13/cast"
)
func main() {
s := cast.ToString(1024)
fmt.Printf("s is a %T, val = %s\\n", s, s)
}
$ go run main.go
// 输出如下
/**
s is a string, val = 1024
*/
# 列表输出
$ go list -m -m all
# # json 输出
$ go list -m -json all
# 输出当前项目的 Module 名称以及依赖报名
helloworld
...
...
github.com/spf13/cast v1.4.1
...
...
# 语法规则:
# 升级次级或补丁版本号
go get -u 包名@版本号
# 仅升级补丁版本号
go get -u=patch 包名@版本号
这里,我们将 spf13/cast
包从 v1.4.1
升级到 1.5.0
,执行如下命令:
go get -u github.com/spf13/cast@v1.5.0
# 输出如下
go: upgraded github.com/spf13/cast v1.4.1 => v1.5.0
查看 go.mod
文件,内容已经更新为:
module helloworld
go 1.19
require github.com/spf13/cast v1.5.0 // indirect
当前项目中有些包已经不再使用了,但是 go.mod
文件中依然定义了依赖关系,可以使用下面的命令自动整理优化 go.mod
文件。
$ go mod tidy
go mod init # 初始化
go mod tidy # 更新 (移除) 依赖文件
go mod download # 下载依赖文件
go mod vendor # 将依赖全部归档到 vendor 目录
go mod edit # 修改依赖文件
go mod graph # 打印依赖关系 图
go mod verify # 校验依赖
到这里,Go Modules
的基础配置及使用已经完成,我们可以快速导入成熟的第三方库来加速开发。
工欲善其事,必先利其器。 现代化项目开发,一个高效的 IDE 必不可少。
全部0条评论
快来发表一下你的评论吧 !