This commit is contained in:
clay 2024-04-25 09:15:44 -04:00 committed by GitHub
commit bb6388588b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 110 additions and 6 deletions

View File

@ -25,6 +25,7 @@ using Emby.Server.Implementations.HttpServer.Security;
using Emby.Server.Implementations.IO;
using Emby.Server.Implementations.Library;
using Emby.Server.Implementations.Localization;
using Emby.Server.Implementations.Metrics;
using Emby.Server.Implementations.Playlists;
using Emby.Server.Implementations.Plugins;
using Emby.Server.Implementations.QuickConnect;
@ -59,6 +60,7 @@ using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.LiveTv;
using MediaBrowser.Controller.Lyrics;
using MediaBrowser.Controller.MediaEncoding;
using MediaBrowser.Controller.Metrics;
using MediaBrowser.Controller.Net;
using MediaBrowser.Controller.Persistence;
using MediaBrowser.Controller.Playlists;
@ -419,12 +421,6 @@ namespace Emby.Server.Implementations
NetManager = new NetworkManager(ConfigurationManager, _startupConfig, LoggerFactory.CreateLogger<NetworkManager>());
// Initialize runtime stat collection
if (ConfigurationManager.Configuration.EnableMetrics)
{
DotNetRuntimeStatsBuilder.Default().StartCollecting();
}
var networkConfiguration = ConfigurationManager.GetNetworkConfiguration();
HttpPort = networkConfiguration.InternalHttpPort;
HttpsPort = networkConfiguration.InternalHttpsPort;
@ -552,6 +548,7 @@ namespace Emby.Server.Implementations
serviceCollection.AddScoped<DynamicHlsHelper>();
serviceCollection.AddScoped<IClientEventLogger, ClientEventLogger>();
serviceCollection.AddSingleton<IDirectoryService, DirectoryService>();
serviceCollection.AddSingleton<IMetricsCollector, PrometheusMetricsCollector>();
}
/// <summary>
@ -579,6 +576,16 @@ namespace Emby.Server.Implementations
SetStaticProperties();
var userDataRepo = (SqliteUserDataRepository)Resolve<IUserDataRepository>();
((SqliteItemRepository)Resolve<IItemRepository>()).Initialize(userDataRepo, Resolve<IUserManager>());
// Initialize runtime stat collection
if (ConfigurationManager.Configuration.EnableMetrics)
{
Resolve<IMetricsCollector>().Initialize();
}
FindParts();
}

View File

@ -0,0 +1,78 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Jellyfin.Data.Enums;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Entities.Audio;
using MediaBrowser.Controller.Entities.Movies;
using MediaBrowser.Controller.Entities.TV;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Metrics;
using Prometheus;
using Prometheus.DotNetRuntime;
namespace Emby.Server.Implementations.Metrics
{
/// <summary>
/// Prometheus backend for metrics.
/// </summary>
public class PrometheusMetricsCollector : IMetricsCollector
{
private readonly ILibraryManager _libraryManager;
private static readonly Gauge _itemCountGauge = Prometheus.Metrics.CreateGauge("jellyfin_library_items_total", "The number of items in the library", new[] { "item_type" });
private static readonly string[] _metricTypes = new string[]
{
nameof(Movie),
nameof(Series), nameof(Season), nameof(Episode),
nameof(MusicArtist), nameof(MusicAlbum), nameof(MusicVideo), nameof(Audio),
nameof(Book),
nameof(PhotoAlbum), nameof(Photo)
};
/// <summary>
/// Initializes a new instance of the <see cref="PrometheusMetricsCollector" /> class.
/// </summary>
/// <param name="libraryManager">The library manager. </param>
public PrometheusMetricsCollector(ILibraryManager libraryManager)
{
_libraryManager = libraryManager;
_libraryManager.ItemAdded += IncrementItemCount;
_libraryManager.ItemRemoved += (s, e) => UpdateItemCount();
}
/// <inheritdoc />
public void Initialize()
{
DotNetRuntimeStatsBuilder.Default().StartCollecting();
UpdateItemCount();
}
private void UpdateItemCount()
{
foreach (var type in _metricTypes)
{
BaseItemKind item;
Enum.TryParse(type, out item);
var query = new InternalItemsQuery
{
IncludeItemTypes = new[] { item }
};
int count = _libraryManager.GetCount(query);
_itemCountGauge.WithLabels(type).Set(count);
}
}
private void IncrementItemCount(object? sender, ItemChangeEventArgs e)
{
var item = e.Item;
var typeName = item.GetType().Name;
if (_metricTypes.Contains(typeName))
{
_itemCountGauge.WithLabels(typeName).Inc();
}
}
}
}

View File

@ -0,0 +1,19 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace MediaBrowser.Controller.Metrics
{
/// <summary>
/// Interface for metric backends.
/// </summary>
public interface IMetricsCollector
{
/// <summary>
/// Initializes metrics.
/// </summary>
public void Initialize();
}
}