Core Data - Data Retention and Persistent Caps
EdgeX 3.1
New in EdgeX 3.1
Note
This feature is for both Core Data and Support Notifications service.
Overview
Core Data service
In use cases, since core data persists data in the local database indefinitely, there is a need to persist the latest recent readings only and clean up the old ones, as keeping an infinite number of readings is considered computationally expensive and can lead to a lack of machine memory. Thus, a retention mechanism is placed on core data to keep a certain number of readings.
Under this mechanism, the maximum readings capacity is called MaxCap
and the minimum readings capacity is called MinCap
. Core data will create an internal schedule according to the Interval
configuration to check if the number of readings are higher than the MaxCap
. When the number of readings reach the MaxCap
, Core data will purge the amount of the readings to the MinCap
.
For example, the MaxCap
is set to 10, the MinCap
is set to 2 and the Interval
is set to 3s. Now, core data will check how many readings are in the local database every 3 seconds. When the number of readings reach 10, core data will check the 3rd reading to find the related event's origin timestamp and perform function DeleteEventsByAge
to delete events by age. This way the related readings will also be deleted.
Introduction
For detailed information on the data retention see Use Case for capping readings in Core Data.
Prerequisite Knowledge
-
For detailed information on the data retention see Core Data Configuration Properties and browse to retention tab.
-
For detailed information on the data retention see Notifications Configuration Properties and browse to retention tab.
Enable Data Retention
Two ways to enable data retention mechanism:
- Using environment variables to override the default configuration
RETENTION_ENABLED: true RETENTION_INTERVAL: <interval> RETENTION_MAXCAP: <maxcap> RETENTION_MINCAP: <mincap>
For detailed information about environment variables override see Service Configuration Overrides.
- Using Core Keeper to override the default configuration, for example, Update Retention's MinCap of core-data from
8000
to10000
, refer to the Core Keeper API documentation for more information.
curl -X PUT "http://localhost:59890/api/v3/kvs/key/edgex/v4/core-data/Retention/MinCap" \
-H "Content-Type: application/json" \
-d '{"value": "10000"}'