Wowza Community

Stream not found for Apple HLS

Hello,

Some time ago i have implemented Switching between live streams

Using lower-level API.

Basically live stream is created. Another incoming live stream and static video is switched (sort of overlay).

Everything was working until recently i saw logs full of following errors:

HTTPStreamerAdapterCupertinoStreamer.onPlaylist: Stream not found [live/smil:lrytas.smil/chunklist_w866886594_b864000_slLT_t64SEk=.m3u8]: lr_hi_NLT

Investigation led to this conclusion:

When live incomming stream reconnection happens and my switcher in playing live stream (is static video is shown nothing happens) apple HLS player (JWPlayer or http://dailymotion.github.io/hls.js/demo/) stops playing.

Page reload returns 404. Server restart solves issue until next reconnect.

I suspect temporal live stream publish of ‘empty’ stream does this.

Wowza test players RTMP, HDS are working then.

Question what to do? Is this apple HLS issue, wowza, or my code?

this is actual switch method:

private void switchStreams(StreamData streamData, boolean showLive, boolean fileHasEnded) {
		if (streamData.provider != null)
			streamData.provider.close();
		streamData.provider = null;
		
		Publisher publisher = streamData.publisher;
		if (showLive) {
			String liveStream = streamData.config.liveStream;
			streamData.provider = new PublishingProviderLive(publisher, publisher.getMaxTimecode(), liveStream);
			streamData.provider.setRealTimeStartTime(System.currentTimeMillis());
			logUtil.info("Stream: " + streamData.name + " switching to live stream: " + liveStream);
		} else {
			String overlay = streamData.config.overlayFile;
			streamData.provider = new PublishingProviderMediaReader(publisher, publisher.getMaxTimecode(), overlay);
			streamData.provider.setRealTimeStartTime(System.currentTimeMillis());
			if (!fileHasEnded) {
				logUtil.info("Stream: " + streamData.name + " switching to overlay: " + overlay);				
			} else {
				logUtil.debug("Stream: " + streamData.name + " restarting overlay file");
			}
			
		}
	}

Stream data class:

private class StreamData {
		String name;
		boolean showLive;
		TranscoderDestinationConfig config;
		
		IPublishingProvider provider;
		Publisher publisher;
		
		public StreamData(String name, boolean showLive, IPublishingProvider provider, Publisher publisher,
				TranscoderDestinationConfig config) {
			
			this.name = name;
			this.showLive = showLive;
			this.config = config;
			this.provider = provider;
			this.publisher = publisher;
		}
		
		boolean play() {
			try {
				return provider.play(publisher);
			} catch (Exception e) {
				logUtil.error("Live playback exception happened: " + e.getMessage());
				return false;
			}
		}
	}

StreamData#play() is called elsewere

BTW.

provider.play(publisher)

Always return false playing a PublishingProviderLive. Why?