Server RAM increase when accessing a tuner

Server Version#: 1.19.3.2852
Player Version#: N/A
Tuner Make/Model: HD Homerun Quattro
Guide/Lineup name: N/A
Using XMLTV?: Yes
Channel number/Name: N/A

I feel this has been happening for a number of versions now (maybe since the first v1.19.x version, I don’t recall seeing it happen on v1.18.x). What seems to happen is when Plex server accesses my tuner the memory usage of the server doubles, from ~2GB to ~4GB (8GB total ram on my Synology NAS).

Take for example this graph:

At this time I simply restarted my Plex server to set the baseline and then within the server settings navigated into the [Live TV & DVR] menu item then clicked into the ‘## enabled’ channels link to show the list of channels for my tuner. There’s a small pause as I assume Plex server is querying the tuner and that is exactly when the memory usage jumps up.
Note that the actions I performed did not involve any player/client activity at all.

I also attach my server logs of this activity.Plex Media Server Logs_2020-05-27_20-07-06.zip (3.5 MB)

A few questions before addressing.

  1. How much memory is installed in the DS1019+ ?
  2. What other applications are running at the time?

It’s the original 8GB total - I did mention that above.

The other applications on the NAS are minimal (only had it a couple of months now so haven’t tried much). Other than the ‘stock’ DSM applications, I have Docker (with 3 containers, none reporting more than 310MB memory used) and Synology Moments.
DSM task manager currently looks like this, if that’s of any use:

What is the breakdown from “Plex Media Server”?

There will be multiple processes listed .

I’m wondering if you’re seeing the transcoder and ComSkip running

Neither of those seem to be showing, just Server, Script Host and Tuner Service.

I’m going to need more data to go on…

Can you please restart PMS and,
try to make it increase memory usage?

I have a suspicion, albeit remote, but would like to see if anything you do triggers it.

Just to check - by stop and restart I do that from DSM package manager (I did this before)?
And then what would you like me to try and do to increase the memory usage? Various player/client activity - direct play, forced transcode, etc?

yes, normal Package Center Stop, pause, Start, pause, Use

OK
I’ve done that and none of the playing actions of non-tuner based content cause the memory usage to increase significantly.

Plex Server restart from DSM - memory usage baseline at around 23%:

Start playing some content (on web browser and then also android phone) - forced transcoding (hw) down to a lower resolution (note: audio was not transcoding). A very small increase in memory usage when starting the 2nd stream (shown at around 38seconds on the graph):

Stop those playing. Start playing some higher quality content, again forced transcoding to a lower resolution, hardware transcode for the video, and this time audio needed transcoding.

Finally, the status in Task Manager in DSM at the end of this activity:

Logs of this: Plex Media Server Logs_2020-05-28_07-52-53.zip (3.7 MB)

To test Live TV activity, I restarted the server, started 2 streams of Live TV (one web browser and one android phone) and that showed no large increase in memory (remained in mid-20%'s).

Then in the settings again I went to the [Live TV & DVR] section, clicked into ‘XX channels’ enabled and again that’s when the memory usage increases dramatically, as before.

These logs: Plex Media Server Logs_2020-05-28_08-10-22.zip (2.9 MB)

Thank you for taking the time to create it for me.
I see what’s happening but cannot explain it.

I’m going to get some help to come look and maybe have a few ideas.

No problem! I’m glad you can see whats happening.
Let me know if you need me to do anything more.

Thanks

I am looking into memory leak issue and I can send you a build with some extra logging for memory use by the plex media server process -

For channel mapping we do have in memory lists of tuner channels and lineup channels for matching but i would not expect that to use up 2gb extra - so the diagnostic will help in seeing how much the increments are and at what point they arise.

So we need to establish if the memory increase is as expected for the number of channels and lineup channels or if we are keeping in memory more than that.

Is there an impact ? any failures ? is the allocated extra memory freed later on ?
Memory

I’m based in the UK so it’s getting late here today, but if you send a test build I can test what you need me to over the weekend.

As far as I can tell the increased memory usage doesn’t have any negative impact to anything I use Plex for, though I wouldn’t call myself a heavy user (one Shield as main TV and a few Android/Apple devices).

However, you mention lineup matching being in memory - that might be something, I use XMLTV and the source file I generate for that using mc2xml is large - I asked about that in another post you had responded to regarding large XMLTV files:

It feels to me like this issue is likely related.

Is there a way to see if the guide refresh could cause a similar issue - is there a way to manually run the guide refresh task? I ask this because originally I thought the guide refresh increased the memory usage but was never sure when the refresh happened to be able to test around that suspicion, but then I found this large increase which is why I created this thread.

From what I have observed, memory is not freed up later on. I haven’t stopped/restarted Plex Server since this morning from the testing I did and currently Plex Dashboard is reporting around mid-40% still, as it was after the increase in the screenshot from earlier today, seen above, and Synology task manager is reporting 3.29GB for the Plex Server process.

We have issued fixes that stopped crashes with some xmltv files - seen with some with 20Mb size, 70Mb and 100Mb size. We are still crashing on some bigger files.

You could send me the xmltv file you are using when you send me logs from the special diagnostic build I sent you

Thanks for the diagnostic logs. I can see memory use increased when the DVR scheduler was running and also again when the XMLTV file was opened by PMS.

On windows the Plex Media Server crashes with this xmltv file. I already have an open issue on this with the development team for a 120Mb xmltv file that crashes PMS.

I will add your xmltv file to the open issue.

The xmltv file was opened to get the channels and that thread used up close to 2Gb of ram.

I will also ask for investigation into whether the memory gets released or kept to be re-used. There may be some kernel aspects here on releasing allocated memory

1 Like

Good morning, thanks for looking into this.

Curiously, starting at around 8pm last night DSM shows total memory usage was gradually reduced and it seems that’s all/mostly from Plex - the Plex Server is only using 1.32GB - less than it does at first startup!

All weekend when I’ve glanced at the stats in Plex (every 4-6hrs or so) it remained in the mid-40%'s.
This was all with the same diagnostic build you sent - I didn’t roll-back to a release version.

image

image

I have grabbed the logs this morning, but I’m not sure if they’re useful or not (do they get cycled at midnight) - I can PM them over if they are?

They would be of benefit if they cover the time when memory used by the process dropped from the 3.97 Gb level I saw in the earlier logs to much less than that

Release 1.20.1 will have improvements to handling of large xmltv guide files.

I sent you alpha build 1.20.1.3187

1 Like

The fix for memory issues with large xmltv files has now been released in Plex Media Server beta 1.20.1.3213 released today

See Release Note: Plex Media Server

  • DVR) Would use excessive amount of memory when loading certain XMLTV guide files (#11501).
1 Like