Skip to content



The Open Network Video Interface Forum (ONVIF) Device Service is a microservice created to address the lack of standardization and automation of camera discovery and onboarding. EdgeX Foundry is a flexible microservice-based architecture created to promote the interoperability of multiple device interface combinations at the edge. In an EdgeX deployment, the ONVIF Device Service controls and communicates with ONVIF-compliant cameras, while EdgeX Foundry presents a standard interface to application developers. With normalized connectivity protocols and a vendor-neutral architecture, EdgeX paired with ONVIF Camera Device Service, simplifies deployment of edge camera devices.

Use the ONVIF Device Service to streamline and scale your edge camera device deployment.

How It Works

The figure below illustrates the software flow through the architecture components.


Figure 1: Software Flow

  1. EdgeX Device Discovery: Camera device microservices probe network and platform for video devices at a configurable interval. Devices that do not currently exist and that satisfy Provision Watcher filter criteria are added to Core Metadata.
  2. Application Device Discovery: Query Core Metadata for devices and associated configuration.
  3. Application Device Configuration: Set configuration and initiate device actions through a REST API representing the resources of the video device (e.g. stream URI, Pan-Tilt-Zoom position, Firmware Update).
  4. Pipeline Control: The application initiates Video Analytics Pipeline through HTTP Post Request.
  5. Publish Inference Events/Data: Analytics inferences are formatted and passed to the destination message bus specified in the request.
  6. Export Data: Publish prepared (transformed, enriched, filtered, etc.) and groomed (formatted, compressed, encrypted, etc.) data to external systems (be it analytics package, enterprise or on-premises application, cloud systems like Azure IoT, AWS IoT, or Google IoT Core, etc.

Getting Started

A brief video demonstration of building and using the device service:

Get Started>


Learn more about EdgeX Core Metadata
Learn more about EdgeX Core Command