Kapacitor
是influxdata开源的流式处理框架,因为初上手go语言,对于它神奇的package管理方式大开眼界,踩了不少坑,所以把mac+Kapacitor+goland的完整调试环境配置记录一下。
另外,仍然有很多无法理解的地方,欢迎指导。
配置中主要参考了以下文档:
brew install go
运行中会显示go被安装在哪里:
==> Downloading https://homebrew.bintray.com/bottles/go-1.12.el_capitan.bottle.tar.gz
######################################################################## 100.0%
==> Pouring go-1.12.1.el_capitan.bottle.tar.gz
==> Caveats
As of go 1.2, a valid GOPATH is required to use the `go get` command:
https://golang.org/doc/code.html#GOPATH
You may wish to add the GOROOT-based install location to your PATH:
export PATH=$PATH:/usr/local/opt/go/libexec/bin
==> Summary
? /usr/local/Cellar/go/1.12.1: 6,435 files, 250.6M
go语言被安装在 /usr/local/Cellar/go/1.12.1
下面。
接下来可以配置GOROOT
等环境变量,如果用的是zsh,在 ~/.zshrc
中设置:(bash
则是~/.bashrc
)
export GOPATH=/usr/local/Cellar/go/1.12.1
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOBIN
令配置文件生效:
source ~/.zshrc
测试是否修改成功:
go env
GOARCH="amd64"
GOBIN="/usr/local/Cellar/go/1.12.1/bin"
GOEXE=""
GOFLAGS=""
GOHOSTARCH="amd64"
GOHOSTOS="darwin"
GOOS="darwin"
GOPATH="/usr/local/Cellar/go/1.12.1"
GOPROXY=""
GORACE=""
GOROOT="/usr/local/Cellar/go/1.12.1/libexec"
...
我们知道 Kapacitor
的源码地址是 https://github.com/influxdata/kapacitor
,但我们并不需要 git clone
下载,这就是 go
的神奇之处=。=
1.下载github库:
go get github.com/influxdata/kapacitor
这会让你在GOPATH
目录下创建 github.com/influxdata/kapacitor
目录,并将源码clone到里面。go语言和github的纠缠到这种程度?
2.接下来按部就班编译即可:
cd $GOPATH/src/github.com/influxdata/kapacitor
cp .hooks/pre-commit .git/hooks/
如果pre-commit这一步出了问题,运行:
go fmt ./...
go vet ./...
3.Build and Test
cd $GOPATH/src/github.com/influxdata/kapacitor
go build ./cmd/kapacitor
go build ./cmd/kapacitord
go test $(go list ./... | grep -v /vendor/)
Kapacitor
正常编译后会在cmd下出现两个package,里面分别是kapacitor
和kapacitord
的启动main文件。测试通过,则说明编译成功:
...
ok github.com/influxdata/kapacitor/udf 0.400s
ok github.com/influxdata/kapacitor/udf/agent 0.041s
? github.com/influxdata/kapacitor/udf/agent/examples/mirror [no test files]
? github.com/influxdata/kapacitor/udf/agent/examples/moving_avg [no test files]
? github.com/influxdata/kapacitor/udf/agent/examples/outliers [no test files]
? github.com/influxdata/kapacitor/udf/test [no test files]
? github.com/influxdata/kapacitor/uuid [no test files]
ok github.com/influxdata/kapacitor/waiter 0.028s
非常神奇的一点是,如果在其他路径下下载github库并编译,会出现一大堆
cannot find package
的问题。
强行解决起来很麻烦,因为很多influxdata自己的github库都重构过了,比如github.com/influxdata/influxdb/influxql
已经被迁移到github.com/influxdata/influxql
了。强行替换又会造成新的问题。那么为什么在
GOPATH
下面可以正常编译呢?不得其解。
原博文链接:https://blog.csdn.net/SoftPoeter/article/details/88954918
betbrain
公司的一系列产品口碑质量都不错,比如大名鼎鼎的Intellij IDEA
, PyCharm
和WebStorm
,从官网下载goland,并安装。但是goland没有免费的社区版,有教育网邮箱可以免费使用,否则可以考虑在Intellij IDEA
中安装go插件
,不赘述。
在goland中打开Kapacitor项目会报empty GOPATH
等错误,按照安装
那一步中的环境变量配置一下即可:
在测试环节我们可以看到有些包有测试例,打开其中一个,比如 combine_test.go
,run或debug均可,断点之后停在第一行:
在 mac
更新到 MoJave` 后,一些编译工具移动了位置,因此debug的时候可能出现报错:
could not launch process: debugserver or lldb-server not found:
install XCode's command line tools or lldb-server
一个简单的解决方法是:
xcode-select --install
mac会提示你下载新的编译工具,下载完成后即可debug。
在ide中run kapacitor
和kapacitord
的main函数即可,console的输出和从brew安装并启动的效果一样 (kapacitor 的 brew 安装参考博文):
守护进程kepacitord启动:
运行工具kapacitor启动:
原博文链接:https://blog.csdn.net/SoftPoeter/article/details/88954918