deviceShifu ConfigMap
apiVersion: apps/v1
import "k8s.io/api/core/v1"
ConfigMap
ConfigMap of Shifu is a Kubernetes-native Kubernetes ConfigMap that is used to store deviceShifu configurations.
- apiVersion: v1
- kind: ConfigMap
- metadata (ObjectMeta)
the standard Kubernetes ObjectMeta - data (map[string]string)
Data for ConfigMap.- driverProperties (DeviceShifuDriverProperties)
- instructions (DeviceShifuInstructions)
- telemetries (DeviceShifuTelemetries)
DeviceShifuDriverProperties
DeviceShifuDriverProperties refer to driver parameters of deviceShifu.
- driverSku (string)
hardware models supported by the driver, such asHikvision Camera
. - driverImage (string)
container image name of the driver, such asdriver/hikvision-camera:v1.2.3
. - driverExecution (string)
execution path of the drive. For command line driver, relative/absolute path of the driver execution file needs to be filled in, such aspython driver.py
orC:\driver.exe
.
DeviceShifuInstructions
DeviceShifuInstructions are all the commands and settings that deviceShifu can receive and issue.
- instructionSettings (DeviceShifuInstructionSettings)
- instructions (map[string]DeviceShifuInstruction) Example:
instructions: |
instructions:
get_value: # The name of the command you want to set
protocolPropertyList: # The parameters of the command have different configurations according to different protocols
DeviceShifuInstruction
DeviceShifuInstruction is the command that deviceShifu can receive.
- protocolPropertyList (map[string]string)(DeviceShifuprotocolPropertyList)
parameters of the deviceShifu command, which have various configurations according to different protocols. Please refer to the examples for more examples. - gatewayPropertyList (map[string]string)(DeviceShifugatewayPropertyList)
Parameters of the deviceShifu command define how deviceShifu forwards requests through the gateway, enabling deviceShifu under different protocols to adapt to a unified protocol, process requests from the server, and push data to the cloud. Please refer to the examples for more implementation details.
DeviceShifuprotocolPropertyList
DeviceShifuprotocolPropertyList parameters of the deviceShifu command, which have various configurations according to different protocols. The following shows the use of MQTT protocol and OPC UA protocol. Please refer to the examples for more examples.
- MQTT
instructions: |
instructions:
get_topicmsg1: # The name of the command you want to set
protocolPropertyList:
MQTTTopic: "/test/test1" # MQTTTopic The topic associated with this command
get_topicmsg2:
protocolPropertyList:
MQTTTopic: "/test/test2"
... # You can continue to configure commands and corresponding topics according to your own needs, just continue to add according to this format
- OPC UA
instructions: |
instructions:
get_value: # The name of the command you want to set
protocolPropertyList:
OPCUANodeID: "ns=2;i=2" # OPCUANodeID The NodeID associated with this command
get_time:
protocolPropertyList:
OPCUANodeID: "i=2258"
... # You can continue to configure commands and corresponding NodeID according to your own needs, just continue to add according to this format
DeviceShifuGatewayPropertyList
The gatewayPropertyList
instruction specifies how to adapt data to a unified protocol resource. The instructions
defines how deviceShifu forwards requests through the gateway by configuring gatewayPropertyList
, enabling multi-protocol devices to communicate with the gateway. The gateway then handles protocol conversion and communication. Please refer to the examples for more examples.
- gateway LwM2M
instructions: |
instructionSettings:
defaultTimeoutSeconds: 8
instructions:
read_value:
gatewayPropertyList:
ObjectId: /3442/0/130 # The LwM2M Object Id
DataType: float # The LwM2M Resource Type
... # You can continue to configure commands and corresponding ObjectId according to your own needs, just continue to add according to this format
DeviceShifuInstructionSettings
DeviceShifuInstructionSettings refers to the settings related to Instructions in deviceShifu.
- defaultTimeoutSeconds (int)
default timeout period (in seconds) for all Instructions. If not set, the default value is 3 seconds
DeviceShifuTelemetries
DeviceShifuTelemetries refer to one or more commands that deviceShifu uses to detect IoT devices.
- telemetrySettings (DeviceShifuTelemetrySettings)
- telemetries (map[string]DeviceShifuTelemetry)
DeviceShifuTelemetrySettings
DeviceShifuTelemetrySettings are the settings related to deviceShifu monitoring.
- defaultPushToServer (bool)
deviceShifu Defaults all telemetry to the push service. default false. - defaultTelemetryCollectionService (string)
deviceShifu Defaults telemetry to push addresses. - HTTP protocol
- telemetryUpdateIntervalInMilliseconds (int64)
millisecond interval at which deviceShifu detects Telemetry. The default value is 3000. - telemetryTimeoutInMilliseconds (int64)
timeout for deviceShifu to connect to the device. The default value is 3000. - telemetryInitialDelayInMilliseconds (int64)
delay time for the initial detection of deviceShifu. The default value is 3000.
- telemetryUpdateIntervalInMilliseconds (int64)
- TCP socket protocol
- telemetryUpdateIntervalInMilliseconds (int64)
millisecond interval at which deviceShifu detects Telemetry. Default is 1000. (Detection method: deviceShifu tries to establish a socket connection with the device once every 1000 milliseconds, and determines if the device is on by whether the connection is successful.)
- telemetryUpdateIntervalInMilliseconds (int64)
- MQTT protocol
- telemetryUpdateIntervalInMiliseconds (int64)
deviceShifu detects the millisecond interval between the MQTT and the receipt of the last msg. Default value is 3000.
- telemetryUpdateIntervalInMiliseconds (int64)
- PLC4X
- telemetryUpdateIntervalInMiliseconds (int64)
deviceShifu The interval (in milliseconds) for detecting Telemetry. (Detection method: using PLC4X to send ping to the device.)
- telemetryUpdateIntervalInMiliseconds (int64)
DeviceShifuTelemetry
DeviceShifuTelemetry describes which commands deviceShifu uses to monitor the status of IoT devices.
- properties (DeviceShifuTelemetryProperties)
- instruction (string)
Indicates the command used for telemetry, and must be a valid command as defined by DeviceShifuInstruction above. - initialDelayMs (int)
Indicates the delay (in milliseconds) to start telemetry. - intervalMs (int)
Indicates the interval of telemetry (milliseconds). - pushSettings (DeviceShifuTelemetryPushSettings)
Used to set up this telemetry push service.
- instruction (string)
DeviceShifuTelemetryPushSettings
DeviceShifuTelemetryPushSettings describes the settings for a telemetry push service for deviceshifu.
- telemetryCollectionService (string)
Indicates the name of the TelemetryService corresponding to the telemetry service. - pushToServer (bool)
Indicates whether this telemetry service is pushed or not.