文档章节

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

o
 osc_1ee7cxmx
发布于 2018/08/06 17:04
字数 400
阅读 8
收藏 0

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

在 docker 中运行 Exceptionless

docker-compose.yml的内容:

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:
      - 5000: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:
      - 5100: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 的配置
"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
    }
 }
  1. StartUp.cs 的配置。
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 官方示例
o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

face-api.js 示例

该示例是基于GitHub的一个开源项目:https://github.com/justadudewhohacks/face-api.js 其核心的库是用js写的,所以它可以在web项目或nodejs 中使用 Html: <!DOCTYPE html><html lang="en......

Canaan_
12分钟前
13
0
树莓派4b + Ubuntu20.04 Server 安装Java8

安装环境: 树莓派4b + Ubuntu20.04 Server 32位 1. 下载jdk https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html 2. 解压 tar -zxvf jdk-8u251-linux-arm32-vf......

SummerGao
45分钟前
9
0
项目实战:Qt+OpenCV图像处理与识别算法平台

若该文为原创文章,未经允许不得转载 原博主博客地址:https://blog.csdn.net/qq21497936 原博主博客导航:https://blog.csdn.net/qq21497936/article/details/102478062 本文章博客地址:h...

红模仿_红胖子
48分钟前
7
0
北京智源大会 | AI + 医疗的下一个十年:从公共卫生预警到人类基因密码破解 道翰天琼认知智能api机器人接口。

医疗事关人身安全,要求极高,容错率极低,因此,知识壁垒和技术壁垒都很高。过去,AI系统更多的是服务于终端,辅助医生诊断、决策。但是,医疗很复杂,直接切入终端问题很多。未来十年,AI+...

jackli2020
52分钟前
16
0
源于HystrixCommandStartStream和RollingCommandMaxConcurrencyStream 的 RxJava demo

其实,最近在工作之余看Hystrix源代码已经有一个多月了, 除了对 HystrixCommandProperties ,HystrixCommand 和AbstractCommand 几个类比较了解以外,其余看山不是山,比较懵, 主要是因为H...

专业写BUG的程序员
55分钟前
16
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部