No.6 – 时序数据库随笔 – 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
brewinstallgo@1.15
...
...
fluxgit:(master) goversion
goversiongo1.15.9darwin/am
  • git
brewinstallgit
git:(master) git--version
gitversion2.30.2
  • bazaar
brewinstallbazaar
git:(master) bzrversion
Bazaar (bzr) 2.7.0
  • rust
curl--proto'=https'--tlsv1.2-sSfhttps://sh.rustup.rs | sh
  • make pkg-config protobuf yarn
brewinstallmakepkg-configprotobufyarn
git:(master) make--version
GNUMake4.3
...
...

如果上面一切顺利,我们设置一下环境变量 ~/.bash_profile :

exportGOPATH=/Users/jincheng/go
exportGOROOT=/usr/local/opt/go@1.15/libexec
exportPKG_CONFIG=/Users/jincheng/go/bin/pkg-config
exportPKG_CONFIG_PATH=$(find/usr/local/Cellar-name'pkgconfig'-typed|greplib/pkgconfig|tr'\n'':'|seds/.$//)
exportPATH=$GOROOT/bin:$GOPATH/bin:$PKG_CONFIG_PATH:$PATH

别忘记 source ~/.bash_profile, 我们进入正题,下载源码。

03 源码构建

很多时候我们对一项功能的了解,需要对源码有一定的了解,学习InfluxDB我们同样需要源码方式进行。

  • 下载
gitclonehttps://github.com/influxdata/influxdb.git
  • 编译
make
...
...
make[2]: Leavingdirectory'/Users/jincheng/work/influxdb/storage/flux'
make[1]: Leavingdirectory'/Users/jincheng/work/influxdb/storage'
envGO111MODULE=ongobuild-tags'assets'-ldflags"-s -w -X main.commit=eeba0f3268"-obin/darwin/influx ./cmd/influx
envGO111MODULE=ongobuild-tags'assets'-ldflags" -X main.commit=eeba0f3268"-obin/darwin/influxd ./cmd/influxd

 如上我们发现会生成两个二进制文件,一个是influxd服务,一个是influx的客户端。

  • 下载依赖
goclean-modcache&&gomodtidy&&gomodvendor

执行完如上命令会在项目目录下生成一个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:]')/influxsetup \
--usernameiot \
--password2021iotdb \
--orgorg \
--bucketiot \
--retention1h \
--tokenwhere-were-going-we-dont-need-roads \
--force

Configdefaulthasbeenstoredin/Users/jincheng/.influxdbv2/configs.
UserOrganizationBucket
iotorgiot

如上执行成功表明我们完成了setup,创建了名为 iot 的bucket,在v2中bucket相当于v1中的database。

  • 插入数据
bin/$(uname-s|tr'[:upper:]''[:lower:]')/influxwrite--bucketiot--precisions"m v=2 $(date +%s)"
bin/$(uname-s|tr'[:upper:]''[:lower:]')/influxwrite--bucketiot--precisions"m v=168 $(date +%s)"
bin/$(uname-s|tr'[:upper:]''[:lower:]')/influxwrite--bucketiot--precisions"n v=222 $(date +%s)"

如上我们插入了3条数据,接下来我们查询一下。

  • 查询数据
bin/$(uname-s|tr'[:upper:]''[:lower:]')/influxquery'from(bucket:"iot") |> range(start:-1h)'

执行之后,我们会查询到刚才插入的数据,同时IDE中调试模式启动的influxd服务也会打印相应的日志信息。

上面是简单查询记录,下面我们在进行一下聚合计算:

bin/$(uname-s|tr'[:upper:]''[:lower:]')/influxquery'from(bucket:"iot") |> range(start:-1h) |> sum()'

到此,我们InfluxDB的调试模式启动服务,客户端创建bucket,插入数据和查询数据就有了一个直观的印象。

06 Flux查询语言

上面我利用influx客户端进行query命令,其实执行的是Flux的查询语言,Flux是influxDB社区提供的新的查询语言,那么Flux是否可以在IDE中进行运行和调试呢?当然!我们对Flux的开发调试环境搭建一下,并且对查询操作进行演示。

  • 下载&编译
gitclonehttps://github.com/influxdata/flux.git
...
make
...
goclean-modcache&&gomodtidy&&gomodvendor
  • GoLand 运行

我们需要配置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

作者介绍

孙金城,社区编辑,Apache Flink PMC 成员,Apache Beam Committer,Apache IoTDB PMC 成员,ALC Beijing 成员,Apache ShenYu 导师,Apache 软件基金会成员。关注技术领域流计算和时序数据存储。

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/303777.html<

(0)
管理的头像管理
上一篇2025-05-25 10:12
下一篇 2025-05-25 10:14

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注