Durable state store plugin
The durable state plugin enables storing and loading key-value entries for durable state actors.
Schema
The durable_state table and durable_state_slice_idx index need to be created in the configured database, see schema definition in Creating the schema.
The durable_state_slice_idx index is only needed if the slice based queries are used.
Configuration
To enable the journal plugin to be used by default, add the following line to your Pekko application.conf:
pekko.persistence.state.plugin = "pekko.persistence.r2dbc.state"
It can also be enabled with the durableStateStorePluginId for a specific DurableStateBehavior and multiple plugin configurations are supported.
See also Configuration.
Reference configuration
The following can be overridden in your application.conf for the journal specific settings:
sourcepekko.persistence.r2dbc {
  # Durable state store
  state {
    class = "org.apache.pekko.persistence.r2dbc.state.R2dbcDurableStateStoreProvider"
    table = "durable_state"
    # When this is enabled the updates verifies that the revision is +1 of
    # previous revision. There might be a small performance gain if
    # this is disabled.
    assert-single-writer = on
    dialect = ${pekko.persistence.r2dbc.dialect}
    schema = ${pekko.persistence.r2dbc.schema}
    use-connection-factory = ${pekko.persistence.r2dbc.use-connection-factory}
    log-db-calls-exceeding = ${pekko.persistence.r2dbc.log-db-calls-exceeding}
    buffer-size = ${pekko.persistence.r2dbc.buffer-size}
    refresh-interval = ${pekko.persistence.r2dbc.refresh-interval}
    behind-current-time = ${pekko.persistence.r2dbc.behind-current-time}
    backtracking {
      enabled = ${pekko.persistence.r2dbc.backtracking.enabled}
      window = ${pekko.persistence.r2dbc.backtracking.window}
      behind-current-time = ${pekko.persistence.r2dbc.backtracking.behind-current-time}
    }
    db-timestamp-monotonic-increasing = ${pekko.persistence.r2dbc.db-timestamp-monotonic-increasing}
    use-app-timestamp = ${pekko.persistence.r2dbc.use-app-timestamp}
    persistence-ids.buffer-size = ${pekko.persistence.r2dbc.persistence-ids.buffer-size}
  }
}
Deletes
The journal supports deletes through hard deletes, which means the durable state store entries are actually deleted from the database. There is no materialized view with a copy of the state so make sure to not delete durable states too early if they are used from projections or queries.