EonaCat.Logger.Pipe
1.0.0
Prefix Reserved
dotnet add package EonaCat.Logger.Pipe --version 1.0.0
NuGet\Install-Package EonaCat.Logger.Pipe -Version 1.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EonaCat.Logger.Pipe" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="EonaCat.Logger.Pipe" Version="1.0.0" />
<PackageReference Include="EonaCat.Logger.Pipe" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add EonaCat.Logger.Pipe --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: EonaCat.Logger.Pipe, 1.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package EonaCat.Logger.Pipe@1.0.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=EonaCat.Logger.Pipe&version=1.0.0
#tool nuget:?package=EonaCat.Logger.Pipe&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
EonaCat.Logger.Pipe
Send logs via Named Pipes (Windows) or Unix Domain Sockets (Unix) using EonaCat.Logger.Pipe.
var serviceProvider = new ServiceCollection()
.AddLogging(builder =>
{
builder.ClearProviders();
builder.AddPipeLogger(options =>
{
options.PipeName = RuntimeInformation.IsOSPlatform(OSPlatform.Windows) ? "MyNamedPipe" : "/tmp/mysocket.sock";
options.MinimumLogLevel = LogLevel.Information;
});
})
.BuildServiceProvider();
var logger = serviceProvider.GetRequiredService<ILogger<Program>>();
logger.LogInformation("This message goes over Named Pipe or Unix Domain Socket!");
Example on how to subscribe to events from the PipeLogger:
var options = new PipeLoggerOptions { PipeName = pipeName };
var provider = new PipeLoggerProvider(options);
var logger = (PipeLogger)provider.CreateLogger("DemoCategory");
// Subscribe to events
logger.OnLogSent += (sender, message) =>
{
Console.WriteLine($"Event: Log sent - {message}");
};
logger.OnLogError += (sender, ex) =>
{
Console.WriteLine($"Event: Logging error - {ex}");
};
// Use the logger directly to log
logger.Log(LogLevel.Information, new EventId(0), "Hello from event demo!", null, (state, ex) => state.ToString());
Example on how subscribe to events from the PipeLoggerProvider:
var provider = new PipeLoggerProvider(options);
provider.OnLogSent += (s, msg) => Console.WriteLine($"Provider event: Log sent - {msg}");
provider.OnLogError += (s, ex) => Console.WriteLine($"Provider event: Log error - {ex}");
// Create a logger and log
var logger = provider.CreateLogger("Demo");
logger.Log(LogLevel.Information, new EventId(0), "Testing provider events", null, (state, ex) => state.ToString());
Example for running your own Named Pipe server:
var pipeName = RuntimeInformation.IsOSPlatform(OSPlatform.Windows) ? "demopipe" : "/tmp/demopipe.sock";
// Start server in background task
var server = new PipeLogServer(pipeName);
var serverTask = server.StartAsync();
// Setup logging with PipeLogger
var services = new ServiceCollection()
.AddLogging(builder =>
{
builder.ClearProviders();
builder.AddPipeLogger(options =>
{
options.PipeName = pipeName;
options.MinimumLogLevel = LogLevel.Information;
});
})
.BuildServiceProvider();
var logger = services.GetRequiredService<ILogger<Program>>();
// Log some messages
for (int i = 0; i < 5; i++)
{
logger.LogInformation($"Test log message #{i + 1}");
await Task.Delay(500);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- EonaCat.Logger (>= 1.4.7)
- Microsoft.Extensions.Logging.Abstractions (>= 9.0.6)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
1.0.0 | 98 | 6/28/2025 |