是否有一种非显而易见的方式(至少对我而言)来添加自定义接收器,例如MongoDB 或 MicrosoftTeams 作为在 ServiceStack 框架中实例化 Serilog 工厂的一部分,还是滚动您自己的工厂和 ILog 的实现?
PM> Install-Package ServiceStack.Logging.Serilog
LogManager.LogFactory = new SerilogFactory();
这在不使用 ServiceStack 实现的情况下工作,但它被认为是错误的形式吗?
public override void Configure(Container container)
{
Log.Logger = new LoggerConfiguration()
.WriteTo.MongoDBCapped("mongodb://mymongourl:27017/mylogs",
collectionName: "mycollectionoflogs", cappedMaxSizeMb: 50,
cappedMaxDocuments: 10000)
.CreateLogger();
SetConfig(new HostConfig
{
DefaultRedirectPath = "/metadata",
DebugMode = AppSettings.Get(nameof(HostConfig.DebugMode), false)
});
}
并在 ServiceInterface 消息实现中:
public object Any(MyRequest request)
{
Log.Information("I'm a lumberjack and I'm OK");
return new MyRequestResponse
{
Result = $"{ results.Chop() }"
};
}
最佳答案
我刚刚在 this commit 中添加了构造函数重载以使用自定义 Serilog 记录器,此更改可从现在的 v5.1.1 获得 available on MyGet .
通过此更改,您可以使用 ServiceStack 的 SerilogFactory
传递自定义 Serilog 记录器,例如:
LogManager.LogFactory = new SerilogFactory(new LoggerConfiguration()
.WriteTo.MongoDBCapped("mongodb://mymongourl:27017/mylogs",
collectionName: "mycollectionoflogs", cappedMaxSizeMb: 50,
cappedMaxDocuments: 10000)
.CreateLogger());
您可以像在您的示例中一样直接使用 Serilog 记录器,除了它无法捕获 ServiceStack 的内置日志或以后无法将其替换为任何其他 ServiceStack loggers .
关于servicestack - 将自定义接收器与 ServiceStack.Logging.Serilog 一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51775580/