天天滚动:No.6 – 时序数据库随笔 – InfluxDB&Flux调试环境搭建
本篇为大家介绍了InfluxDB和Flux的开发调试环境,便于后续对上一篇提到的用户问题进行解决的操作演示。
01 上篇回顾
(资料图)
这是上一篇结尾我们抛出来的InfluxDB社区问题,那么要想解决这个问题,我们首先先建立InfluxDB的开发环境,以源码的方式了解其应用和实现。所以本篇我们为搭建介绍InflxuDB的开发调试环境。
02 依赖安装
要想进行InfluxDB的开发调试,我们需要一些基础软件安装(MacOS),如下:
brew/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"go
brew install go@1.15......flux git:(master) ✗ go versiongo version go1.15.9 darwin/amgit
brew install gitgit:(master) ✗ git --versiongit version 2.30.2bazaar
brew install bazaargit:(master) ✗ bzr versionBazaar (bzr) 2.7.0rust
curl --proto "=https" --tlsv1.2 -sSf https://sh.rustup.rs | shmake pkg-config protobuf yarn
brew install make pkg-config protobuf yarngit:(master) ✗ make --versionGNU Make 4.3......
如果上面一切顺利,我们设置一下环境变量 ~/.bash_profile :
export GOPATH=/Users/jincheng/goexport GOROOT=/usr/local/opt/go@1.15/libexecexport PKG_CONFIG=/Users/jincheng/go/bin/pkg-configexport PKG_CONFIG_PATH=$(find /usr/local/Cellar -name "pkgconfig" -type d | grep lib/pkgconfig | tr "\n" ":" | sed s/.$//)export PATH=$GOROOT/bin:$GOPATH/bin:$PKG_CONFIG_PATH:$PATH
别忘记 source ~/.bash_profile, 我们进入正题,下载源码。
03 源码构建
很多时候我们对一项功能的了解,需要对源码有一定的了解,学习InfluxDB我们同样需要源码方式进行。
下载git clone https://github.com/influxdata/influxdb.git编译
make......make[2]: Leaving directory "/Users/jincheng/work/influxdb/storage/flux"make[1]: Leaving directory "/Users/jincheng/work/influxdb/storage"env GO111MODULE=on go build -tags "assets" -ldflags "-s -w -X main.commit=eeba0f3268" -o bin/darwin/influx ./cmd/influxenv GO111MODULE=on go build -tags "assets" -ldflags " -X main.commit=eeba0f3268" -o bin/darwin/influxd ./cmd/influxd
如上我们发现会生成两个二进制文件,一个是influxd服务,一个是influx的客户端。
下载依赖go clean -modcache && go mod tidy && go mod vendor
执行完如上命令会在项目目录下生成一个vendor目录,里面下载了go.mod里面配置的项目所有依赖。
04 GoLand运行调试
GoLand是进行Go开发调试的IDE工具,我们后面关于InfluxDB源码部分分享就在GoLand环境中进行。
IDE配置
在GoLand中进行InfluxDB的开发调试,需要简单的配置一下,GOROOT/GOPATH/Go Modules ,如图:
其中GOROOT/GOPATH和~/.bash_profile保持一致。
运行主服务运行 influxd/main.go ,出现如下界面证明已经influxd的服务已经启动成功,并在8086端口监听。
如果一切顺利,那么服务监听在8086端口。
调试主服务我们如果看看源代码的执行路径,往往我们期望debug的方式运行 influxd/main.go ,如果出现debug启动出现如下错误,说明我们的环境变量没有在IDE中生效:
如上情况我们可以创建或者在~/.zshrc中增加一行配置让 ~/.bash_profile配置生效。
source ~/.bash_profile
然后重启电脑,再试一下。如果顺利,我们设置一下断点,可以类似界面如下:
如果一切顺利,那么调试模式下的服务也是监听8086端口。
05 操作测试
好的,服务启动了,下面我们利用客户端继续数据操作的测试。上面编译的时候大家发现其实我们会生成2个二进制可执行文件,一个是influxd,一个是influx。我们刚才debug启动了influxd的服务,我们同样可以启动influx的客户端,进行数据操作,客户端我们之间运行可执行文件(如果你愿意也可以IDE启动)。
初始化bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx setup \--username iot \--password 2021iotdb \--org org \--bucket iot \--retention 1h \--token where-were-going-we-dont-need-roads \--forceConfig default has been stored in /Users/jincheng/.influxdbv2/configs.User Organization Bucketiot org iot
如上执行成功表明我们完成了setup,创建了名为 iot 的bucket,在v2中bucket相当于v1中的database。
插入数据bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx write --bucket iot --precision s "m v=2 $(date +%s)"bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx write --bucket iot --precision s "m v=168 $(date +%s)"bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx write --bucket iot --precision s "n v=222 $(date +%s)"
如上我们插入了3条数据,接下来我们查询一下。
查询数据bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx query "from(bucket:"iot") |> range(start:-1h)"
执行之后,我们会查询到刚才插入的数据,同时IDE中调试模式启动的influxd服务也会打印相应的日志信息。
上面是简单查询记录,下面我们在进行一下聚合计算:
bin/$(uname -s | tr "[:upper:]" "[:lower:]")/influx query "from(bucket:"iot") |> range(start:-1h) |> sum()"
到此,我们InfluxDB的调试模式启动服务,客户端创建bucket,插入数据和查询数据就有了一个直观的印象。
06 Flux查询语言
上面我利用influx客户端进行query命令,其实执行的是Flux的查询语言,Flux是influxDB社区提供的新的查询语言,那么Flux是否可以在IDE中进行运行和调试呢?当然!我们对Flux的开发调试环境搭建一下,并且对查询操作进行演示。
下载&编译git clone https://github.com/influxdata/flux.git...make...go clean -modcache && go mod tidy && go mod vendorGoLand 运行
我们需要配置flux的命令,为 repl,然后运行,如下:
启动repl之后,我们可以进行数据处理操作,如下图:
查询数据Flux可以直接和InfluxDB服务连接,进行数据查询,上面我们在influx客户端输入的查询语句其实就是Flux查询语言,那么我们当然可以在Flux中进行数据查询,我们启动Flux repl,进行查询如下:如下:
import "influxdata/influxdb"data = influxdb.from(bucket:"iot") |> range(start:-1h) |> sum()data |> yield()
如图,发生了错误,原因是Flux去尝试连接influxdb的9999端口服务,不过我们上面看到我们的服务是监听8086了,所以我们要修改一下默认端口(这就是源码debug的好处了)。
修改端口之后,我们发现连接已经建立,但是权限还有问题,如下:
这个就需要我们连接的Token信息,如下:
cat ~/.influxdbv2/configs
我们读取数据时候携带token和org信息,如下:
import "influxdata/influxdb"data = influxdb.from(bucket:"iot", token:"where-were-going-we-dont-need-roads", org:"org") |> range(start:-1h) |> sum()data |> yield()
好,到这里我们Flux读取InfluxDB数据部分也有了一个直观的了解。
07 InfluxDB&Flux社区贡献
目前看InflxdbV2版本的贡献者并不多,我在源码构建的时候发现的这些默认端口问题都是influx社区待改进的patch,我也提交了相关的PRs。
For InfluxDB: https://github.com/influxdata/influxdb/pull/20809
For Flux: https://github.com/influxdata/flux/pull/3514
作者介绍
孙金城,清一色社区编辑,ApacheFlinkPMC成员,ApacheBeamCommitter,ApacheIoTDBPMC成员,ALCBeijing成员,ApacheShenYu导师,Apache软件基金会成员。关注技术领域流计算和时序数据存储。
关键词:
-
天天滚动:No.6 – 时序数据库随笔 – InfluxDB&Flux调试环境搭建
2023-05-06 -
为抗病毒连喝近五升白开水,女子“水中毒”进ICU抢救
2023-05-06 -
2023第十届乌镇戏剧节艺术委员会换届了吗 全球观焦点
2023-05-06 -
美容护理行业2022年报及2023一季报总结:厚积薄发,龙头成长可期
2023-05-06 -
坩埚价格暴涨3倍,晶科、晶澳、天合抢签新单!885亿元光伏长单潮背后:四大变化!
2023-05-06 -
83岁泰斗成CBA总决赛最大赢家 辽宁浙江他都曾指导 世界今亮点
2023-05-06 -
观察:保和丸的功效与作用饭前还是饭后_保和丸的功效与作用
2023-05-06 -
“江苏好人”刘爱红:30多年如一日 悉心照料患病公婆
2023-05-06 -
中汽协:一季度中国汽车整车出口同比增长1.5倍
2023-05-06 -
全球今日讯!张文宏:新冠病毒还会存在,大流行已经过去
2023-05-06 -
320万美元建一座加氢站贵不贵?成本还能更低吗|天天最新
2023-05-06 -
洛阳:千年古都年轻化表达 让魅力出圈成常态
2023-05-06 -
教你一招丨端午还未到粽叶已热销 选购粽叶注意闻、摸、看
2023-05-06 -
世界快消息!第133届广交会闭幕,现场出口成交216.9亿美元
2023-05-06 -
电脑关机后老是自动重启怎么办(电脑关机后总是自动重启怎么解决)
2023-05-06 -
环球微速讯:或将命名为A7 全新奥迪A6骡车谍照曝光
2023-05-06 -
支付宝余额冻结怎么解冻资金_支付宝余额冻结怎么解冻
2023-05-06 -
【全球独家】天津高考批次ab段怎么分普通本科 是什意思录取是什意思
2023-05-06 -
环球即时:朱标不死朱棣会造反吗_朱标
2023-05-06 -
股票行情快报:白银有色(601212)5月5日主力资金净买入323.76万元
2023-05-06 -
中超-洛卡迪亚点射制胜 沧州客场1-0深足迎赛季首胜
2023-05-05 -
抖音火山版怎么看以前看过的视频_抖音火山版怎么显示观看历史|全球通讯
2023-05-05 -
天天速看:赛意信息:公司高管拟以300万至500万元增持公司股份
2023-05-05 -
闲置太阳能农场好玩吗 闲置太阳能农场玩法简介_天天热消息
2023-05-05 -
今日观点!生活用品上市公司龙头股票有哪些?哪些股票值得关注?(2023/5/5)
2023-05-05 -
小米5怎么样值得买吗_小米5怎么样-环球新动态
2023-05-05 -
事关报销!洛阳市医保结算方式有调整 环球微动态
2023-05-05 -
每日观察!今日MSI对战队伍数据前瞻:R7 vs GAM
2023-05-05 -
2023昆山中考成绩查询入口+投档录取时间 天天要闻
2023-05-05 -
当前关注:上调1.9万元,特斯拉中国调整全新Model S及Model X涨价
2023-05-05
-
守住网络直播的伦理底线
2021-12-16 -
石窟寺文化需要基于保护的“新开发”
2021-12-16 -
电影工作者不能远离生活
2021-12-16 -
提升隧道安全管控能力 智慧高速让司乘安心
2021-12-16 -
人民财评:提升消费体验,服务同样重要
2021-12-16 -
卫冕?突破?旗手?——武大靖留给北京冬奥会三大悬念
2021-12-16 -
新能源车险专属条款出台“三电”系统、起火燃烧等都可保
2021-12-16 -
美术作品中的党史 | 第97集《窗外》
2021-12-16 -
基金销售业务违规!浦发银行厦门分行等被厦门证监局责令改正
2021-12-16 -
保持稳定发展有支撑——从11月“成绩单”看中国经济走势
2021-12-16