The following will be the primary feature focus areas for our upcoming release.
Retention policies allow an operator to define a specific Stream size or data age. Any data beyond this threshold will be automatically purged.
The current transactions API is functional, however it is cumbersome and requires detailed knowledge of Pravega to configure appropriate values such as timeouts. This work will simplify the API and automate as many timeouts as possible.
Focus is on testing and strengthening exactly once guarantees and correctness under failure conditions.
This will expose a new low-level reader API that provides access the low level byte stream as opposed to the event semantics offered by the Java Client API. This can also be leveraged in the future to build different flavors of reader groups.
Security for this release will focus on support for securing Pravega external interfaces along with basic access controls on stream access and administration.
- Access Control on Stream operations.
- Auth between Clients and Controller/SegmentStore.
- Auth between SegmentStore and Tier 2 Storage.
Pravega ecosystem interconnectivity will be augmented with the following:
- Expanded Flink connector support (batch & table API support).
- Logstash connector.
- Others also under consideration (Interested in writing a connector? Talk to us on Slack)
The following items are new features that we wish to build in upcoming Pravega releases, however many active work is currently underway. Please reach out on the Pravega channels if you're interested in picking one of these up.
- Operational Features
- Non-disruptive and rolling upgrades for Pravega
- Provide default Failure Detector
- Exposing information for administration purposes
- Ability to define throughput quotas and other QoS guarantees
- Pravega Connectors / Integration
- Kafka API Compatibility (Producer and Consumer APIs)
- Spark connectors (source/sink)
- REST Proxy for Reader/Writer (REST proxy for Admin operations is already there)
- Stream Management
- Stream aliasing
- Ability to logically group multiple Streams
- Ability to assign arbitrary Key-Value pairs to streams - Tagging
- Tiering Support
- Policy driven tiering of Streams from Streaming Storage to Long-term storage
- Support for additional Tier 2 Storage backends