zoukankan      html  css  js  c++  java
  • .NetCore 使用Zipkin 分布式服务追踪监控服务性能

    参考资料

    https://zipkin.io/

    https://github.com/openzipkin/zipkin/

    https://github.com/openzipkin/zipkin4net

    搭建环境

    CentOS 7.X

    Java 8 SDK

    zipkin官网有三种安装方式可以参考

    Docker

    docker run -d -p 9411:9411 openzipkin/zipkin

    Java

    如果你已经拥有Java8的环境可以如下安装

    curl -sSL https://zipkin.io/quickstart.sh | bash -s
    java -jar zipkin.jar

    源码安装

    git clone https://github.com/openzipkin/zipkin
    cd zipkin
    ./mvnw -DskipTests --also-make -pl zipkin-server clean install
    java -jar ./zipkin-server/target/zipkin-server-*exec.jar

    安装好之后访问下地址看下Zipkin效果

    .NetCore中怎么来使用Zipkin

    首先添加如下2个nuget包

    为了不使Configure方法太过臃肿,我这里扩展下需要用到的IApplicationBuilder接口

    在Configure中注入IApplicationLifetime 、ILoggerFactory两个对象

      app.UserZipkinCore(applicationLifetime, loggerFactory);
    public static void UserZipkinCore(this IApplicationBuilder app,IApplicationLifetime applicationLifetime,ILoggerFactory loggerFactory)
            {
                applicationLifetime.ApplicationStarted.Register(() =>
                {
                    TraceManager.SamplingRate = 1.0f;
                    var logger = new TracingLogger(loggerFactory, "zipkin4net");
                    var httpsender = new HttpZipkinSender("http://ipaddress:9411", "application/json");
                    var tracer = new ZipkinTracer(httpsender, new JSONSpanSerializer());
                    TraceManager.RegisterTracer(tracer);
                    TraceManager.Start(logger);
                });
                applicationLifetime.ApplicationStopped.Register(() => TraceManager.Stop());
                app.UseTracing("IdentityServer4"); 
            }
    SamplingRate:跟踪日志的颗粒度
    UseTracing:在Zipkin上新建的服务名称

    启动引用程序查看Zipkin中的记录

    关于Zipkin的界面功能就不做特别介绍一看都懂

     
     
  • 相关阅读:
    mysql-5-aggregation
    mysql-4-functions
    mysql-3-orderby
    技术之心 | 云信和TA们携手打响防疫战
    疫情下的传统商企自救|4个Tips搭建销量过亿直播间
    那些2019年会爆发的泛娱乐黑科技风口
    流量难、获客难、增长难?增长黑客思维“解救”B端业务
    【翻译】Facebook全面推出Watch Party,可多人线上同看直播视频
    深入浅出聊一聊Docker
    C++写日志方法调试
  • 原文地址:https://www.cnblogs.com/liyouming/p/9228297.html
Copyright © 2011-2022 走看看