Mappers

Overview

Mapper is an application that is used to connect and control devices. The responsibilities of mapper are as follows:

  • Scan and connect to the device.
  • Collect telemetry data from device.
  • Standardize device data.
  • Push and Pull the device data.
  • Set up the expected state of device-twin.
  • Check health of the device.(todo)

KubeEdge uses Device Controller, Device Twin and Mapper to control the devices. The Device Controller is on the cloud side, it uses CRD to define and control devices. The Device Twin is on the edge side, it stores the value/status from the Mapper and transfers the messages with Device Controller and Mapper. Meanwhile, DMI in the Device Twin is used for registing mapper and transfer Device Instance and Device Model to user Mapper.

How to create your own Mappers

Now we use Mapper Framework to genenrate your own Mapper to control the edge devices.

1. Design the device model and device instance CRDs

If you don’t know how to define the configuration files of Device Model and Device Instance, please get more details in the page.

2. Generate the Mapper project

The command below will generate a framework for the basic Mapper. Run the command and input your mapper’s name:

  1. make generate
  2. Please input the mapper name (like 'Bluetooth', 'BLE'): foo

A project named as your input will be generated. The file tree is as below:

  1. mapper
  2. ├── cmd ------------------------ Main process.
  3. └── main.go ------------------ Almost need not change.
  4. ├── config.yaml ---------------- Configuration file including DMI's grpc settting
  5. ├── data ----------------------- Publish data and database implementation layer, almost need not change
  6. │ ├── dbmethod ----------------- Provider implement database interfaces to save data
  7. │ │ ├── influxdb2 -------------- Implementation of Time Series Database(InfluxDB)
  8. │ │ │ └── client.go ------------ InfluxDB client
  9. │ │ ├── redis -------------------Implementation of K/V Database(Redis)
  10. │ │ │ └── client.go ------------ Redis client
  11. │ │ └── tdengine ---------------Implementation of Time Series Database(TDengine)
  12. │ │ └── client.go ------------ TDengine client
  13. │ └── publish ------------------ Publisher implement push interfaces to push data,will add more protocols in the future
  14. │ ├── http ----------------- HTTP client will push data to server
  15. │ │ └── client.go --------- WIP
  16. │ └── mqtt ----------------- MQTT client will push data to broker
  17. │ └── client.go ------- WIP
  18. ├── device --------------------- Implementation device layer, almost need not change
  19. │ ├── device.go ---------------- Device control, almost need not change
  20. │ └── devicetwin.go ------------ Push twin data to EdgeCore, almost need not change
  21. ├── Dockerfile
  22. ├── driver --------------------- Device driver layer, complete TODO item in this
  23. │ ├── devicetype.go ------------ Refine the struct as your CRD
  24. │ └── driver.go ---------------- Fill in the functions like getting data/setting register.
  25. ├── hack
  26. │ └── make-rules
  27. │ └── mapper.sh
  28. └── Makefile

In most cases, you need to fill in the code in the driver folder as follows: In the devicetype.go file, you need to fill in the ProtocolConfig and VisitorConfig structure information in the way you defined in the instance yaml file, so that the mapper can correctly parse the configuration information. In the driver.go file, you need to customize the method of initializing the device and obtaining device data, and standardize the data collected by the mapper. In config.yaml, you need to define the protocol name of mapper.

3. Deploy your mapper

After generating the mapper project and filling driver folder, users can make their own mapper image based on the Dockerfile file and deploy the mapper in the cluster through deployment and other methods.

  1. docker build -t [YOUR MAPPER IMAGE NAME] .

The following is an example of a mapper Deployment:

  1. apiVersion: apps/v1
  2. kind: Deployment
  3. metadata:
  4. name: mapper-test
  5. namespace: default
  6. spec:
  7. replicas: 1
  8. selector:
  9. matchLabels:
  10. app: demo
  11. template:
  12. metadata:
  13. labels:
  14. app: demo
  15. spec:
  16. nodeName: edge-node # Replace with your edge node name
  17. containers:
  18. - name: demo
  19. volumeMounts: #Required, mapper need to communicate with grpcclient
  20. - mountPath: /etc/kubeedge
  21. name: test-volume
  22. env: #Not Required, this field is used to mount the user database key
  23. - name: TOKEN
  24. valueFrom:
  25. secretKeyRef:
  26. name: demo-secret
  27. key: token
  28. image: docker.io/library/mapper-demo:v1.0.1 # Replace with your mapper image name
  29. imagePullPolicy: IfNotPresent
  30. resources:
  31. limits:
  32. cpu: 300m
  33. memory: 500Mi
  34. requests:
  35. cpu: 100m
  36. memory: 100Mi
  37. command: [ "/bin/sh","-c" ]
  38. args: [ "/kubeedge/main --config-file /kubeedge/config.yaml --v 4" ]
  39. volumes:
  40. - name: test-volume
  41. hostPath:
  42. path: /etc/kubeedge
  43. type: Directory

You can deploy the mapper using the same way in Kubernetes:

  1. kubectl apply -f <path to mapper yaml>

If you want to debug locally first, you can also compile and run the mapper code directly:

  1. go run cmd/main.go --v <log level,like 3> --config-file <path to config yaml>

Examples

We currently provide virtual device mapper, modbus protocol mapper and USB protocol mapper as examples of Mapper Framework:

We will provide more build-in mappers like onvif and bluetooth later.