Amazon Kinesis Video Streams enables you to securely ingest, process, and store video and time-encoded data from devices at any scale for real-time and batch-oriented machine-vision based applications that power smart homes, smart cities, industrial automation, security monitoring, and more. Kinesis Video Streams provides SDKs that make it easy to securely stream video to Amazon Web Services from connected devices. Amazon Kinesis Video Streams supports HTTP Live Streaming (HLS) to enable live and on-demand playback of video ingested from devices on any browser or mobile app. It also durably stores, encrypts, and indexes the video streams and provides easy-to-use APIs so that applications can access and retrieve indexed video fragments based on tags and timestamps. Kinesis Kinesis Video Streams also provides a library to integrate machine learning with video streams to build custom applications. Kinesis Video Streams automatically provisions and elastically scales all the infrastructure needed to ingest video streams from millions of devices.
Key features
SDKs to securely stream data from devices
Amazon Kinesis Video Streams provides SDKs in C++ and Java that you can build and configure for your connected devices. These SDKs manage receiving data from the device's media source and securely transmitting it to a Kinesis video stream on a frame-by-frame basis in real-time. The SDK is also available as a GStreamer-plugin for constructing custom media-data flows.
To learn more about the SDKs, see the documentation.
Live and on-demand video playback with HTTP Live Streaming (HLS)
Amazon Kinesis Video Streams enables playback of the ingested video using a fully-managed HTTP Live Streaming (HLS) capability. As devices stream video into Kinesis Video Streams, you can do live playback and replay archived video on any browser or mobile platform.
Extract images for enhanced playback or Machine Learning applications
Amazon Kinesis Video Streams offers APIs and SDKs to help you extract images from your video streams. You can use these images for enhanced playback applications such as thumbnails or enhanced scrubbing, or for use in Machine Learning pipelines. To learn more, see the documentation.
Be notified when media is ready for consumption
Amazon Kinesis Video Streams will notify you via SNS when a media fragment is persisted and ready for consumption. To learn more, see the documentation.
Real-time APIs
Amazon Kinesis Video Streams offers easy-to-use APIs that allow you to retrieve the data from your streams on a frame-by-frame basis for building real-time applications.
Support for low-latency two-way media streaming with WebRTC
Amazon Kinesis Video Streams supports WebRTC for low-latency, peer-to-peer, two-way media streaming. WebRTC is an open-source project that enables real-time media streaming and interaction between web browsers, mobile applications, and connected devices via simple APIs.
Kinesis Video Streams includes managed end-points for WebRTC signaling that allows applications to securely connect with each other for peer-to-peer live media streaming. Next, it includes managed end-points for TURN that enables media relay via the cloud when applications cannot stream peer-to-peer media. It also includes managed end-points for STUN that enables applications to discover their public IP address when they are located behind a NAT or a firewall. Additionally, it provides easy to use SDKs to enable camera IoT devices with WebRTC capabilities. Finally, it provides client SDKs for Android, iOS, and for Web applications to integrate Kinesis Video Streams WebRTC signaling, TURN, and STUN capabilities with any WebRTC compliant mobile or web player.
To learn more about this capability, see the documentation.
Durable storage
Amazon Kinesis Video Streams uses Amazon S3 as the underlying data store, which means your data is stored durably and reliably. You can set and control retention periods on a per-stream basis, allowing you to cost-effectively store the data in your streams for a limited time period or indefinitely. You can change the stream retention period at any point.
Pay per use
With Amazon Kinesis Video Streams, you pay only for the volume of data you ingest, store, and consume through the service. There are no upfront costs or minimum fees, and you need not worry about paying for idle video streams. For more information, see the pricing page.
Automatic indexing for retrieval
Amazon Kinesis Video Streams automatically indexes the data you store in your video streams based on timestamps generated by the device, or timestamps generated by Kinesis Video Streams when it receives the video. You can combine stream-level tags with timestamps to easily search and retrieve specific video fragments for playback, analytics, and other processing.
Video stream parser library
Amazon Kinesis Video Streams offers a stream parser library that you can use within your applications to easily retrieve frame-level objects, extract and collect metadata attached to fragments, merge consecutive fragments, and more. It allows you to readily integrate popular ML frameworks such as Apache MxNet, TensorFlow, and OpenCV. For more information, see the documentation.
Automatic data encryption in transit and at rest
The Amazon Kinesis Video Streams SDK encrypts the frames and fragments generated by the device’s hardware for secure streaming using Transport Layer Security (TLS), a protocol that provides privacy and data integrity between two communicating applications.
Amazon Kinesis Video Streams automatically encrypts the data you put into your video streams using Amazon Key Management Service (KMS), helping you protect your data at rest. Data is encrypted before it is written to the Kinesis Video Streams storage, and it is decrypted after it is retrieved from storage. As a result, your data is always encrypted at rest within the stream. To learn more, see the documentation.
Access control with Amazon IAM
Amazon Kinesis Video Streams integrates with Amazon Identity and Access Management (IAM), enabling you to control access to your video streams. You can create policies that allow only specific users and groups to take specific actions such as putting data into, or retrieving data from your video streams. For more information about using IAM policies with Kinesis Video Streams, see the documentation.
Time-encoded data
Time-encoded data is any data in which the records are in a time series, and each record is related to its previous and next records. Video is an example of time-encoded data, where each frame is related to the previous and next frames through spatial transformations. Other examples of time-encoded data include audio, RADAR, and LIDAR signals. Amazon Kinesis Video Streams is designed specifically for cost-effective, efficient ingestion and storage of all kinds of time-encoded data for analytics and ML use cases.
Fully managed
Amazon Kinesis Video Streams is fully managed, so there is no infrastructure to manage. Kinesis Video Streams automatically provisions and elastically scales to millions of devices, and scales down when the devices are not transmitting video, without the need to provision a fleet of servers.