Serilog Seq Sink with Docker 不会捕获事件



我在Windows 10 Professional上的Net Core 3.1上运行Web api和控制台应用程序。我有控制台、文本文件、json 文件、mssql 和 seq 的接收器。它们各自记录所有事件,但 seq 不记录任何事件。

我用以下命令安装了Docker:

docker run -d --restart unless-stop --name seq -e ACCEPT_EULA=Y -v D:\Logs\Seq:/data -p 8081:80 datalust/seq:latest

我用这段代码创建了记录器:

Log.Logger = new LoggerConfiguration()
.MinimumLevel.Information()
.MinimumLevel.Override("Microsoft", LogEventLevel.Warning)
.MinimumLevel.Override("System", LogEventLevel.Warning)
.Enrich.FromLogContext()
.Enrich.WithMachineName()
.Enrich.WithEnvironmentUserName()
.Enrich.WithProcessId()
.Enrich.WithThreadId()
.WriteTo.Console()
.WriteTo.File($@"{Constants.LogsDirectory}log-.txt", LogEventLevel.Information, rollingInterval: RollingInterval.Day)
.WriteTo.File(new JsonFormatter(), $@"{Constants.LogsDirectory}log-.json", rollingInterval: RollingInterval.Day)
.WriteTo.MSSqlServer(DatabaseAccess.ConnectionString(context), nameof(ProcessMessageLog), columnOptions: columnOptions)
.WriteTo.Seq("http://localhost:8081")
.CreateLogger();

我在 D:\Logs\Seq 目录中的 seq.json 文件中看到以下内容:

"api": {
"listenUris": [
"http://localhost:8081"
],

我还看到每分钟写入一次的日志文件,但它们都没有通过 Web api 或控制台应用程序捕获事件。

当我去localhost:8081时,我收到一条"localhost refused to connect."消息。

我怀疑我的端口号有误,但我不知道。它们在 1( docker 设置、2( seq.json 值、3( 记录器创建之间应该不同还是相同?

看来Docker中的Seq容器不能很好地与我的micro SD卡D:驱动器配合使用。我只是从那个切换到我的 C: 驱动器,它工作正常。

最新更新