(2018 年第二季度:
请注意,对于vgo 项目,GOPATH
可能最终会被弃用,而支持基于项目的工作流程。这将避免GOPATH
两年前我在下面提出的基于手动项目的手动)
对于 Go 1.11(2018 年 8 月),GOPATH
可以是可选的,带有 modules。
VSCode 越来越支持它:
2016 年 6 月:您不必只依赖一个GOPATH
(即一个工作区)。
我的完整GOPATH
包括:
也就是两条路:
export GOPATH=/path/to/myproject:$HOME/go
为我的所有项目拥有一个 $GOPATH 目录不是很安全,因此所有必需的第 3 方库都安装在同一个 lib 目录中,并且每当我编译项目时,它只使用它需要的库。
这在实践中很糟糕吗?为什么?
我不喜欢这种做法,因为不同的项目可能需要同一个库的不同版本。
这就是为什么我GOPATH
每个项目都有一个,我的构建脚本(与项目一起版本化)为我设置。
当我克隆我的一个 go 项目时,我:
- 将我设置
GOPATH
为那个 go 项目(本地路径,我需要为该项目安装的第三方库,并移动到一个vendor
文件夹),
- 为该路径创建一个符号链接
<myproject>/src/<myproject> -> ../..
,因为GOPATH
手段 go 期望找到myproject
in的来源src/<apackage>
。
那个组织:
- 保持兼容
go get
,
- 确保我需要的任何特定依赖项默认安装在我的项目文件夹中,而不是在全局
GOPATH
.
我有:
myproject
mysource.go
apackage
othersource.go
src
myproject -> ../..
vendor
third-party packages
在 Windows 上,典型的构建脚本是:
λ more b.bat
@echo off
setlocal EnableDelayedExpansion
if not defined GOROOT (
echo Environment variable GOROOT must be defined, with %%GOROOT%%\bin\go.exe
exit /b 1
)
set PATH=C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem
set PATH=%PATH%;%GOROOT%/bin
set GOPATH=%~dp0;%HOME%/go
set prjname=%GOPATH:~0,-1%
for %%i in ("%prjname%") do set "prjname=%%~ni"
rem echo prjname='%prjname%'
if not exist src (
mkdir src
)
if not exist src\%prjname% (
mklink /J src\%prjname% %GOPATH%
)
pushd %~dp0
cd src\%prjname%
rem cd
go install
popd
endlocal
任何克隆我的 go 项目的人都只需输入“ b
”。