You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
BookingHeChuan/Myshipping.Core/Logging/Component/LoggingFileComponent.cs

69 lines
2.4 KiB
C#

2 years ago
using Furion.Logging;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using System;
using System.Text;
namespace Myshipping.Core;
2 years ago
/// <summary>
/// 日志写入文件的组件
/// </summary>
public sealed class LoggingFileComponent : IServiceComponent
{
public void Load(IServiceCollection services, ComponentContext componentContext)
{
// 日志记录
// 每天创建一个日志文件
services.AddLogging(builder =>
{
builder.AddFile("logs/error/{0:yyyyMMdd}_.log", options =>
{
SetLogOptions(options, LogLevel.Error);
});
builder.AddFile("logs/info/{0:yyyyMMdd}_.log", options =>
{
SetLogOptions(options, LogLevel.Information);
});
builder.AddFile("logs/warn/{0:yyyyMMdd}_.log", options =>
{
SetLogOptions(options, LogLevel.Warning);
});
});
}
private void SetLogOptions(FileLoggerOptions options, LogLevel logLevel)
{
options.WriteFilter = (logMsg) =>
{
return logMsg.LogLevel == logLevel;
};
options.FileNameRule = fileName =>
{
return string.Format(fileName, DateTime.UtcNow);
};
options.FileSizeLimitBytes = 5000 * 1024;
//options.MessageFormat = (logMsg) =>
//{
// var stringBuilder = new StringBuilder();
// stringBuilder.AppendLine("【日志级别】:" + logMsg.LogLevel);
// stringBuilder.AppendLine("【日志时间】:" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
// stringBuilder.AppendLine("【日志内容】:" + logMsg.Message);
// if (logMsg.Exception != null)
// {
// stringBuilder.AppendLine("【异常信息】:" + logMsg.Exception);
// }
// stringBuilder.AppendLine("【ManagedThreadId】" + System.Threading.Thread.CurrentThread.ManagedThreadId);
// if (logMsg.Context != null && logMsg.Context.Properties != null && logMsg.Context.Properties.Count > 0)
// {
// foreach (var prop in logMsg.Context.Properties)
// {
// stringBuilder.AppendLine($"【属性】{prop.Key}{prop.Value}");
// }
// }
// return stringBuilder.ToString();
//};
2 years ago
}
}