asp.net core 使用 docker 中的 Exceptionless 实现日志记录

本文展示使用 docker 部署 Exceptionless ,并在 asp.net core mvc 项目中使用 Exceptionless 完成日志记录。

在 docker 中运行 Exceptionless

docker-compose.yml的内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
version: '3.4'

services:
api:
depends_on:
- elasticsearch
image: exceptionless/api-ci:latest
environment:
AppMode: Development
ConnectionStrings__Elasticsearch: http://elasticsearch:9200
ConnectionStrings__Redis: redis,abortConnect=false
RunJobsInProcess: 'false'
StorageFolder: /app/storage
ports:
- 9100:80
volumes:
- appdata:/app/storage

jobs:
depends_on:
- api
image: exceptionless/job-ci:latest
command: run-all
environment:
AppMode: Development
ConnectionStrings__Elasticsearch: http://elasticsearch:9200
ConnectionStrings__Redis: redis,abortConnect=false
StorageFolder: /app/storage
volumes:
- appdata:/app/storage

ui:
image: exceptionless/ui-ci:latest
environment:
AppMode: Development
BaseUrl: http://ex-api.localtest.me:5000
ports:
- 8080:80

elasticsearch:
image: slideroom/elasticsearch:98
environment:
bootstrap.memory_lock: 'true'
discovery.type: single-node
ES_JAVA_OPTS: '-Xms512m -Xmx512m'
xpack.security.enabled: 'false'
ports:
- 9200:9200
- 9300:9300
ulimits:
memlock:
soft: -1
hard: -1
volumes:
- esdata:/usr/share/elasticsearch/data

# kibana:
# depends_on:
# - elasticsearch
# image: slideroom/kibana:116
# ports:
# - 5601:5601

redis:
image: redis:alpine
ports:
- 6379:6379

volumes:
esdata:
driver: local
appdata:
driver: local

docker-compose.yml 文件目录下执行 docker-compose up 命令。
运行成功后可以在 <本地ip>:5100 访问UI

使用本地 Exceptionless 的配置

  1. 创建新的账号并登录 Exceptionless。
  2. 创建项目,获得 api 密钥。
  3. 引用 nuget包,程序包管理器控制台执行 Install-Package Exceptionless.AspNetCore,也可以从 Nuget 上安装强名称程序包 Exceptionless.AspNetCore.Signed
  4. appSettings.json 的配置

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    "Exceptionless": {
    // api 密钥
    "ApiKey": "xDCAoTAteqTbscdJeBDCjMoKbshQYUyC7khhKFhc",
    // api 暴露的地址
    "ServerUrl": "http://localhost:5000",
    "DefaultData": {
    "JSON_OBJECT": "{ \"Name\": \"Blake\" }",
    "Boolean": true,
    "Number": 1,
    "Array": "1,2,3"
    },
    "DefaultTags": [ "xplat" ],
    "Settings": {
    "FeatureXYZEnabled": false
    }
    }
  5. StartUp.cs 的配置。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) 
    {
    app.UseExceptionless(Configuration);
    //OR
    //app.UseExceptionless(new ExceptionlessClient(c => c.ReadFromConfiguration(Configuration)));
    //OR
    // app.UseExceptionless("W79xLqh2B79nm7LZvfAlH47Fxggk9tAaoIvJH3A0");
    //OR
    //loggerFactory.AddExceptionless("API_KEY_HERE");
    //OR
    //loggerFactory.AddExceptionless((c) => c.ReadFromConfiguration(Configuration));

    loggerFactory.AddExceptionless();
    loggerFactory.AddConsole(Configuration.GetSection("Logging"));
    loggerFactory.AddDebug();
    app.UseMvc();
    }

以上配置就可以自动将所有未处理异常发送到 Exceptionless 了,也可以通过 ex.ToExceptionless().Submit() 向 Exceptionless 发送已处理的异常。

参考

  1. .NET Core微服务之基于Exceptionless实现分布式日志记录 - Edison Chou
  2. Exceptionless 官方示例
0%