本文介绍 Windows7 x64 基于 IntelliJ IDEA 搭建 Go 语言开发环境。主要是一些操作过程截图以及简单文字描述,如有不清楚的地方,欢迎指正。所有软件使用当前(2016.12.02)最新版本,旧版或新版可能存在细微差异。
一、网络代理软件 cntlm
从 这里 下载最新 0.92.3 版本 cntlm。cntlm 作用是方便在 Windows 下执行 go get 。参照以下注意事项,并保留监听端口为默认的 3128,其它具体安装及配置参考《cntlm内网代理的代理》。
注意事项:
确保 cntlm.ini 有以下这些配置项
Username <工号>
Domain china
Auth NTLM
PassNT <按实际配置>
PassLM <按实际配置>
Proxy XXXX:8080
NoProxy localhost, 127.0.0., 10., 192.168.*
Listen 3128必须安装在默认路径 C:\Program Files (x86)\Cntlm,非默认路径会有 问题
Windows 下的 cntlm 服务不稳定,有时需手动重启下服务恢复,原因未知。我在桌面创建了一个cntlm.bat,如果网络访问有问题,执行 cntlm.bat 重启下服务(可以考虑将 cntlm 放在 Linux 或 docker 中运行,服务会比较稳定。我就把 cntlm 放在 docker 中运行,如果你已有 docker 环境,可以找我要镜像)。
cntlm.bat 文件内容如下:
net stop cntlm
net start cntlm安装配置后,记得启动服务,可直接运行 cntlm.bat
二、Go 1.7.4
下载 go1.7.4.windows-amd64.msi,保留默认安装路径(C:\Go\),一路 Next 。
配置环境变量(右击 计算机 -> 高级系统设置 -> 高级 -> 环境变量):
添加环境变量 GOPATH ,值为 D:\Codes\go
将 D:\Codes\go\bin 添加到 PATH,方便执行其目录下的程序
三、Git v2.11.0.windows.1
下载 64-bit Git for Windows Setup,保留默认安装路径(C:\Program Files\Git)及所有默认配置,一路 Next。
打开 Git Bash(在桌面右击鼠标 -> Git Bash here),执行 Git 基本配置:
用户和邮箱
git config –global user.name XXXX
git config –global user.email XXXX支持长路径
git config –global core.longpaths true导出和提交时不做文本格式转换
git config –global core.autocrlf false配置网络代理,使用上面 cntlm 服务
git config –global http.proxy 127.0.0.1:3128不校验ssl证书
git config –global http.sslVerify false
四、Go 命令行工具
这篇文章 提到 10+ 个命令行工具,其中比较有用的是 goimports 和 golint,以下以安装这两个工具为例,如需安装其它工具,操作步骤类似。
golang.org/x 仓库即使 FQ 也访问不了,一般做法是从 GitHub 镜像仓库下载,放置在 golang.org/x 对应路径,再执行安装。Git Bash 中执行:
安装 goimports
export GOPATH=”D:\Codes\go”
git clone https://github.com/golang/tools.git $GOPATH/src/golang.org/x/tools
go install golang.org/x/tools/cmd/goimports使用 go get 安装 golint(依赖上一步下载的 golang.org/x/tools 包)
go get -v github.com/golang/lint/golint
如果执行失败,排查上述操作步骤并重启 cntlm 服务,打开一个新的 Git Bash 试试;执行成功会生成两个可执行程序(后面 File Watchers 插件会用到)。
注:开发过程,依赖 GitHub 的包,也可以使用 go get 下载。
五、IntelliJ IDEA 2016.3
下载 IntelliJ IDEA 免费版,保留默认安装路径,一路 Next。
安装后,运行 IDEA:
如果之前安装过旧版本,继承之前配置选择第1项;否则默认第2项即可
选择自己喜欢的皮肤,其它一路 Next
六、安装 IDEA 插件
6.1 访问插件仓库需要配置网络代理(安装完插件后,可以去掉配置)
碰到这样的对话框一律”Accept”
或者勾选以下复选框
6.2 搜索并安装 Go 和 File Watchers,2个插件安装完后重启 IDEA
6.3 配置 Go 插件
6.4 创建 hello 工程
工程路径没有要求,建议先放在 D:\Codes\go\src\hello
注意:.idea 和 hello.iml 由 IDEA 自动生成和管理,不要手工修改。
创建 go 源文件 main.go
写一段简单代码,验证运行是否正常
运行结果
6.5 配置 File Watchers 插件
File Watchers 是工程级别的设置,所以要在上一步工程的基础上操作
File -> Settings… -> Tools -> File Watchers
-w $FilePath$
-set_exit_status $FilePath$
将File Watchers 配置导出,保存在用户 home 目录下
以后创建新工程,直接导入该配置,避免重复配置(点第1个按钮切换到用户 home 目录)
编辑 .go 文件后保存,goimports 会对代码进行格式化(这里仅缩进对齐)
格式化后效果如下
golint 会检查编程风格(这里提示变量名不要使用下划线)
七、IDEA 使用
7.1 运行配置
已存在一个配置项 “Build main.go and run”(这是刚才执行运行生成的)
点击左上角 “+” 按钮,可以创建新的运行配置
配置项命名为 hello,以 Package 方式运行 hello 包,可执行程序存放目录、运行目录设置为 D:\Codes\go\bin
下拉框选择 hello,点击执行按钮
生成的可执行文件放置到指定输出目录
7.2 调试
鼠标左击编辑框行号位置,可以打断点,点击调试按钮启动调试
IDEA 使用了 Go 插件自带的 delve 工具进行调试
点击 “Debugger” 标签页可以查看调用栈,变量等信息
7.3 libraries 设置
IDEA 的 Go 工程默认会加载 GOPATH 环境变量,GOPATH 可以配置多个目录,允许代码分散在多个目录中。
关于如何组织代码,是个持续争论的话题…
虽然代码组织方式灵活,但也存在麻烦。在版本控制系统(svn,git)中,如果代码分散在多个地方,很容易漏提交 — 自己环境上能够运行的工程,遗漏提交其它目录下的依赖包,别人导出的代码运行不了。一种方法是不使用 GOPATH,依赖包通过 vendor 机制和代码放在唯一目录下,也提交到版本库,IDEA 工程仅添加版本库导出目录(bin/pkg/src的父目录)到 “Project libraries”。
八、IDEA 的一些设置
从 File -> Settings… 打开设置窗口
不打开上次工程
Appearance & Behavior -> System Settings
去掉 Startup/Shutdown -> Reopen last project on startup退出时不需确认
Appearance & Behavior -> System Settings
去掉 Startup/Shutdown -> Confirm application exit去掉拼写检查
Editor -> Inspections
去掉 Spelling -> Typo显示行号
Editor -> General -> Appearance
勾选 Show line numbers编辑器字体
Editor -> Colors & Fonts -> Fonts控制台字体
Editor -> Colors & Fonts -> Console Fonts换行符
Editor > Code Style
Line Separator (for new files),最好设置为 Unix and OSX(\n)缩进格式
Editor -> Code Style -> Go终端
Tools -> Terminal
Shell Path 设置为 “C:\Program Files\Git\bin\bash.exe” –login -i
Git Bash 提供比 cmd.exe 多得多的功能,墙裂建议将终端设置为 Git Bash,开发过程可以在其中执行很多命令!
遗留:
IDEA 还支持 MacOS 和 Linux,通过 X Server 能够在 Windows 远程运行 Linux IDEA,方便调试 Linux 上的代码,后续再补充。