실시간 스트림 미리 가져오기

IMA SDK는 실시간 스트림 및 VOD로 수익을 창출하는 데 사용할 수 있습니다. 라이브 스트림의 경우 각 광고 시점에 대해 새로운 광고 요청을 해야 합니다. 모든 시청자가 요청하지 않도록 시차를 두고 요청을 보내세요. 광고를 동시에 게재하며 광고 서버를 지연시킬 수 있습니다.

이를 위해 IMA SDK에는 AdsRequest.liveStreamPrefetchSeconds 속성 이 속성은 SDK의 최대 시간(초)을 지정합니다. 호출한 후 광고 서버에 연결하기 전에 대기해야 합니다. AdsLoader.requestAds() 실제 요청 시간은 무작위로 지정됩니다. 대상 예를 들어 AdsRequest.liveStreamPrefetchSeconds를 30으로 설정하면 SDK는 실제로 사용자가 실제로 실행하기 위해 AdsLoader.requestAds()를 호출한 후 0~30초 동안 서버에 요청할 수 있습니다

라이브 스트림 프리패치의 실제 사용 사례

광고 시점이 완료되는 즉시 다음 광고 시점을 미리 가져오는 것이 좋습니다. 이렇게 하면 프리패치 기간에 사용할 수 있는 최대 시간이 보장됩니다. 다음 광고 시점 사이에 5분의 간격이 있다고 가정해 보겠습니다. 광고 시점이 완료되면 프리패치 기간 290초로 다음 광고 시점을 요청할 수 있습니다 (5분에서 10초를 뺀 값, 프리페치 창에서 해결할 수 있는 충분한 시간이 있습니다.

// 5 minutes == 300 seconds. Include a 10 second buffer
var AD_INTERVAL = 290;

function onAdEvent(adEvent) {
  var ad = adEvent.getAd();
  switch(adEvent.type) {
    case google.ima.AdEvent.Type.ALL_ADS_COMPLETED:
      // Pre-fetch our next ad break.
      requestAds();
      // Play those ads in 5 minutes. In a real-world implementation,
      // this is likely done as the result of a message from your
      // streaming server, not a timeout.
      setTimeout(playAds, AD_INTERVAL * 1000);// Convert to ms.
  }
}

function requestAds() {
  // Destroy the current AdsManager, in case the tag you requested previously
  // contains post-rolls (don't play those now).
  if (adsManager) {
    adsManager.destroy();
  }
  // Your AdsLoader will be set up on page-load. You should re-use the same
  // AdsLoader for every request. For more info on setting up the AdsLoader,
  // see the "Get Started" guide in the prerequisites above.
  if (adsLoader) {
    // Reset the IMA SDK.
    adsLoader.contentComplete();
  }
  var adsRequest = new google.ima.AdsRequest();
  adsRequest.adTagUrl = '...';
  adsRequest.linearAdSlotWidth = <linear_width>;
  adsRequest.linearAdSlotHeight = <linear_height>;
  adsRequest.nonLinearAdSlotWidth = <nonlinear_width>;
  adsRequest.nonLinearAdSlotHeight = <nonlinear_height>;
  adsRequest.liveStreamPrefechSeconds = AD_INTERVAL;
  adsLoader.requestAds(adsRequest);
}

function playAds() {
  adsManager.init(
      <linear_width>,  <linear_height>, google.ima.ViewMode.NORMAL);
  adsManager.start();
}