> 文档中心 > edgex进阶系列-1.通用能力

edgex进阶系列-1.通用能力


1 通用能力

edgex的SDK和代码框架中,提供了一些基础能力,如从配置文件读取配置,使用service client调用其他服务,构建消息pipeline等。

配置读取

  • edgex的配置文件使用toml的格式
  • 通常放在和main.go同级的res包下面
  • 可以通过目录来分割不同的profile或者运行环境。在启动时可以用 -p xxx来激活不同的配置文件。

edgex进阶系列-1.通用能力

自定义配置项

可以在配置文件中以toml的格式加入自己的配置项,

edgex进阶系列-1.通用能力

并在系统启动时,通过service.LoadCustomConfig方法加载进来

edgex进阶系列-1.通用能力

当然,配置的项应该与配置文件中保持一致。

edgex进阶系列-1.通用能力

环境变量覆盖配置

配置的加载过程经过的方法大致如下:

1. main.go: pkg.NewAppService(serviceKey)2. service.go: service.Initialize()3. service.go: bootstrap.RunAndReturnWaitGroup()4. bootstrap.go: configProcessor.Process()5. config.go: envVars.OverrideConfiguration(serviceConfig)

结合下面的源码中,可以看到,edgex最后会以环境变量中的配置替换配置文件中的配置

edgex进阶系列-1.通用能力

这在docker-compose的配置文件中也能看出一些端倪。也可以看出:

  • 配置项的key是忽略大小写的
  • 在环境变量中,使用下划线_分割层级

edgex进阶系列-1.通用能力

这项能力能够实现根据不同的环境,使用不同的配置,不需要为每套环境都构建一套docker。

服务间调用

edgex将系统自带的服务进行了封装,可以像调用本地方法一样实现服务的调用。

edgex进阶系列-1.通用能力

使用

比如在处理消息时,需要查询设备的profile信息,则可以:

edgex进阶系列-1.通用能力

配置

使用这个前提是,在配置文件中配置了服务的地址。DeviceClient的API是属于core-metadata服务的,因此要配置core-metadata的地址。

edgex进阶系列-1.通用能力

当然注释中也说了:

edgex进阶系列-1.通用能力

消息处理总线messagebus

edgex可以通过service.SetFunctionsPipeline()方法构建一个消息处理的管道。

edgex进阶系列-1.通用能力

我们可以在管道中加入自己的处理过程,这个等后面自定义自己的application的时候再细说。tion的时候再细说。