媒体播放器客户端可以在每次对象请求时向内容分发网络 (CDN) 传输有价值的信息。传输这些数据可以改善 QoS 监控、自适应流量优化和交付性能,最终增强消费者体验。
ExoPlayer 中的实现基于 CTA-5004 中定义的规范。
Exoplayer 中的 CMCD 支持
ExoPlayer 中的 CMCD 支持仅可用于自适应流格式,例如 DASH、HLS 和 SmoothStreaming。
CMCD 数据键
CMCD 数据键分为四种不同的类型
- CMCD-Request:其值随每个请求而变化的键。
- CMCD-Object:其值随请求对象而变化的键。
- CMCD-Status:其值不会随每个请求或对象而变化的键。
- CMCD-Session:其值在会话期间预计保持不变的键。
数据传输模式
CMCD 数据可以通过两种方法之一传输
- 作为自定义 HTTP 请求头,这是**默认**行为。
- 作为 HTTP 查询参数。
启用 CMCD
要启用 CMCD,您需要创建一个 CmcdConfiguration.Factory
实例并将其传递给 MediaSource.Factory
,后者在构建播放器时使用。您可以使用默认的 CmcdConfiguration.Factory
,也可以提供您自己的自定义工厂,该工厂在为给定媒体项创建自适应媒体源时每次都会被调用。
使用默认配置工厂启用 CMCD
Kotlin
// Create media source factory and set default cmcdConfigurationFactory. val mediaSourceFactory = DefaultMediaSourceFactory(context) .setCmcdConfigurationFactory(CmcdConfiguration.Factory.DEFAULT)
Java
// Create media source factory and set default cmcdConfigurationFactory. MediaSource.Factory mediaSourceFactory = new DefaultMediaSourceFactory(context) .setCmcdConfigurationFactory(CmcdConfiguration.Factory.DEFAULT);
使用自定义配置工厂启用 CMCD
Kotlin
val cmcdConfigurationFactory = object : CmcdConfiguration.Factory { override fun createCmcdConfiguration(mediaItem: MediaItem): CmcdConfiguration { val cmcdRequestConfig = object : CmcdConfiguration.RequestConfig { override fun isKeyAllowed(key: String): Boolean { return key == "br" || key == "bl" } override fun getCustomData(): ImmutableListMultimap<@CmcdConfiguration.HeaderKey String, String> { return ImmutableListMultimap.of( CmcdConfiguration.KEY_CMCD_OBJECT, "key1=stringValue") } override fun getRequestedMaximumThroughputKbps(throughputKbps: Int): Int { return 5 * throughputKbps } } val sessionId = UUID.randomUUID().toString() val contentId = UUID.randomUUID().toString() return CmcdConfiguration(sessionId, contentId, cmcdRequestConfig, MODE_QUERY_PARAMETER) } } // Create media source factory and set your custom cmcdConfigurationFactory. val mediaSourceFactory = DefaultMediaSourceFactory(context) .setCmcdConfigurationFactory(cmcdConfigurationFactory)
Java
CmcdConfiguration.Factory cmcdConfigurationFactory = mediaItem -> { CmcdConfiguration.RequestConfig cmcdRequestConfig = new CmcdConfiguration.RequestConfig() { @Override public boolean isKeyAllowed(String key) { return key.equals("br") || key.equals("bl"); } @Override public ImmutableListMultimap<@HeaderKey String, String> getCustomData() { return ImmutableListMultimap.of( CmcdConfiguration.KEY_CMCD_OBJECT, "key1=stringValue"); } @Override public int getRequestedMaximumThroughputKbps(int throughputKbps) { return 5 * throughputKbps; } }; String sessionId = UUID.randomUUID().toString(); String contentId = UUID.randomUUID().toString(); return new CmcdConfiguration(sessionId, contentId, cmcdRequestConfig, MODE_QUERY_PARAMETER); }; // Create media source factory and set your custom cmcdConfigurationFactory. MediaSource.Factory mediaSourceFactory = new DefaultMediaSourceFactory(context) .setCmcdConfigurationFactory(cmcdConfigurationFactory);
CMCD 数据示例
这些示例说明了获取媒体片段时发送的数据的有效数据组合
作为自定义 HTTP 请求头
CMCD-Session:sid="6e2fb550-c457-11e9-bb97-0800200c9a66"
CMCD-Request:mtp=25400 CMCD-Object:br=3200,d=4004,ot=v,tb=6000 CMCD-Status:bs,rtp=15000 CMCD-Session:sid="6e2fb550-c457-11e9-bb97-0800200c9a66"
作为 HTTP 查询参数
?CMCD=sid%3D%226e2fb550-c457-11e9-bb97-0800200c9a66%22
?CMCD=br%3D3200%2Cbs%2Cd%3D4004%2Cmtp%3D25400%2Cot%3Dv%2Crtp %3D15000%2Csid%3D%226e2fb550-c457-11e9-bb97- 0800200c9a66%22%2Ctb%3D6000