国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - .NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

2022-01-22 22:14chester·chen ASP.NET教程

這篇文章介紹了.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

 

什么是Elastic AMP

Elastic APM 是一個應(yīng)用程序性能監(jiān)控系統(tǒng)。它可以請求的響應(yīng)時間、數(shù)據(jù)庫查詢、對緩存的調(diào)用、外部 HTTP 請求等的詳細(xì)性能信息,可以實時監(jiān)控軟件服務(wù)和應(yīng)用程序。這可以幫助我們快速查明和修復(fù)性能問題。

Elastic APM 還會自動收集未處理的錯誤和異常。因此我們可以在出現(xiàn)新錯誤時識別它們并密切關(guān)注特定錯誤發(fā)生的次數(shù)。

服務(wù)器指標(biāo)是另一個重要的信息來源。Elastic APM 代理會自動獲取基本的主機(jī)級別指標(biāo)和特定于代理的指標(biāo)。

Elastic APM 目前支持 Node.js, Python, Ruby, PHP, Java, Go, RUM (JS), 和.NET.

 

工作原理

  • Elastic AMP 通過Agent收集應(yīng)用程序的指標(biāo)信息
  • Agent將收集的信息上傳至AMP Server
  • AMP Server對數(shù)據(jù)進(jìn)行聚合后,存儲至Elasticsearch
  • 通過Kibana查看指標(biāo)信息

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

環(huán)境安裝

我們通過Docker搭建一個單機(jī)的環(huán)境來演示Elastic APM的功能。

1.安裝ElasticSearch

docker network create elastic

docker pull docker.elastic.co/elasticsearch/elasticsearch:7.15.2

docker run -d --name es01-test --net elastic -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" docker.elastic.co/elasticsearch/elasticsearch:7.15.2

2.安裝Kibana

docker pull docker.elastic.co/kibana/kibana:7.15.2

docker run -d --name kib01-test --net elastic -p 5601:5601 -e "ELASTICSEARCH_HOSTS=http://es01-test:9200" docker.elastic.co/kibana/kibana:7.15.2

3.安裝ElasticAPM

docker run -d  -p 8200:8200  --name=apm-server --net elastic  --user=apm-server  docker.elastic.co/apm/apm-server:7.15.2  --strict.perms=false -e  -E output.elasticsearch.hosts=["es01-test:9200"]

 

代碼演示

Elastic AMP支持.NET Framwork4.6.1+和.NET Core2.1+,支持的組件有:

GRPC,HttpClient,EF6,EFCore,ElasticSearch,Mysql,Mongo,Redis,Kafka,RabbitMQ等,具體詳見https://www.elastic.co/guide/en/apm/agent/dotnet/master/supported-technologies.html。我們這次使用.NET Framwork新建一個Web項目來演示

 

1.新增Web項目

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

2.新增Nuget包

  <package id="Elastic.Apm" version="1.12.1" targetFramework="net472" />
  <package id="Elastic.Apm.AspNetFullFramework" version="1.12.1" targetFramework="net472" />
  <package id="Elastic.Apm.SqlClient" version="1.12.1" targetFramework="net472" />
  <package id="Elastic.Apm.StackExchange.Redis" version="1.12.1" targetFramework="net472" />
  <package id="StackExchange.Redis" version="2.2.88" targetFramework="net472" />

 

3.配置HttpModule

web.config中的system.webServer中新增以下節(jié)點

      <modules>
          <add name="ElasticApmModule" type="Elastic.Apm.AspNetFullFramework.ElasticApmModule, Elastic.Apm.AspNetFullFramework" />
      </modules>

 

4.配置Agent

我們可以通過環(huán)境變量配置Agent的信息

        protected void Application_Start()
        {
            Environment.SetEnvironmentVariable("ELASTIC_APM_SERVICE_NAME", "TestFromworkSite");  //服務(wù)名
            Environment.SetEnvironmentVariable("ELASTIC_APM_ENVIRONMENT", "Dev");    //環(huán)境
            Environment.SetEnvironmentVariable("ELASTIC_APM_SERVER_URL", "http://localhost:8200"); // APM server
            Environment.SetEnvironmentVariable("ELASTIC_APM_FLUSH_INTERVAL", "5s");  //上傳數(shù)據(jù)的周期
            Environment.SetEnvironmentVariable("ELASTIC_APM_LOG_LEVEL", "Trace");
            //..........
        }

 

5.啟動網(wǎng)站

直接啟動網(wǎng)站即可在Kibana中看到對應(yīng)的Service:TestFromworkSite

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

Elastic APM核心模塊

 

1.Transaction:我們通過Transaction可以看其中Api的調(diào)用信息

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

2. Dependencies:通過Dependencies看到服務(wù)依賴關(guān)系

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

3. Error: 能通過Error看到程序中的錯誤信息

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

4. Matrics: 可以通過Matrics看到服務(wù)氣的內(nèi)存與CPU信息

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

Elastic監(jiān)控MSSql與Redis等組件

新增MSSqlHelper

public class MSSqlHelper
    {
        public static DataSet SqlExecuteReader(string _sql, SqlParameter[] _parameters, CommandType _type = CommandType.Text, string _constring = @"Data Source=.SQLEXPRESS;Initial Catalog=dev;Integrated Security=True;")
        {
            DataSet ds = new DataSet();
            try
            {
                using (SqlConnection conn = new SqlConnection(_constring))
                {
                    SqlCommand cmd = new SqlCommand(_sql, conn);
                    if (_parameters != null)
                    {
                        foreach (SqlParameter p in _parameters)
                        { cmd.Parameters.Add(p); }
                    }
                    cmd.CommandType = _type;
                    cmd.CommandTimeout = 10;//超時時間,單位S
                    conn.Open();
                    using (SqlDataAdapter sda = new SqlDataAdapter())
                    {
                        sda.SelectCommand = cmd;
                        sda.Fill(ds);//填充dataset
                    }
                }
                return ds;
            }
            catch (Exception ex)
            {
                throw;
            }
        }
    }

新增RedisHelper

public class RedisHelper
    {
        private static IDatabase database;

        public static void UseApmForRedis()
        {
            var connection = ConnectionMultiplexer.Connect("127.0.0.1:6379");
            connection.UseElasticApm();
            database = connection.GetDatabase();
        }

        public static void StringSet(string key,string value)
        {
            database.StringSet(key,value);
        }
    }

在Application_Start()中開啟SqlServer與Redis的監(jiān)控

            Agent.Subscribe(new SqlClientDiagnosticSubscriber());
            RedisHelper.UseApmForRedis();

HomeController.Index接口中新增sqlserver與Redis的調(diào)用

public ActionResult Index()
        {
            MSSqlHelper.SqlExecuteReader("select * from S_dev.UserObject", null);

            RedisHelper.StringSet("a", "a");
        }

啟動程序即可看到MSSql與Redis的相關(guān)數(shù)據(jù)

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

 

Elastic APM Api的深入使用

1.StartTransaction與StartSpan開啟自定義transaction與span

一些定時任務(wù)同樣可以使用Elastic APM的Agent.Tracer.StartTransaction和來監(jiān)控,并且我們可以通過StartSpan來新增一個自定義節(jié)點,這種方式需要我們自己處理異常信息。我們新增一個Job

public class TestJob
    {
        public void Run()
        {
            while (true)
            {
                var trans = Agent.Tracer.StartTransaction("TestJob", ApiConstants.TypeRequest);
                try
                {
                    MSSqlHelper.SqlExecuteReader("select * from S_dev.UserObject", null);

                    RedisHelper.StringSet("a", "a");

                    trans.SetLabel("name", "chester");

                    var span = trans.StartSpan("自定義Span", ApiConstants.TypeExternal, ApiConstants.SubtypeHttp, ApiConstants.ActionQuery);
                    try
                    {
                        //Http request
                    }
                    catch (Exception e)
                    {
                        span.CaptureException(e);
                    }
                    finally
                    {
                        span.End();
                    }
                    Thread.Sleep(1000);
                }
                catch (Exception ex)
                {
                    trans.CaptureException(ex);
                    throw;
                }
                finally
                {
                    trans.End();
                }
            }
        }
    }

Application_start中啟動Testjob

Task.Run(() => new TestJob().Run());

啟動程序即可看到對應(yīng)的TestJob監(jiān)控

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

2.CaptureTransaction與CaptureSpan開啟自定義transaction與span

CaptureTransaction與CaptureSpan相對于StartTransaction與StartSpan可以幫助我們結(jié)束Transaction與Span,也可以自動捕獲異常,新增一個TestJob2

public class TestJob2
    {
        public void Run()
        {
            while (true)
            {
                Agent.Tracer.CaptureTransaction("TestJob2", ApiConstants.TypeRequest, (trans) =>
                {
                    MSSqlHelper.SqlExecuteReader("select * from S_dev.UserObject", null);

                    RedisHelper.StringSet("a", "a");

                    trans.SetLabel("name", "chester");

                    trans.CaptureSpan("自定義Span2", ApiConstants.TypeDb, (s) =>
                    {
                        //execute db query
                    }, ApiConstants.SubtypeMssql, ApiConstants.ActionQuery);

                    Thread.Sleep(1000);
                });
            }
        }
    }

Application_start中啟動Testjob2

 Task.Run(() => new TestJob2().Run());

啟動程序即可看到對應(yīng)的TestJob2監(jiān)控

.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法

3.Agent全局?jǐn)r截

我們可以通過過濾器攔截Transaction與Span,并為其添加例如label等附加內(nèi)容

Agent.AddFilter((ITransaction t) =>
            {
                //t.SetLabel("foo", "bar");
                return t;
            });
            Agent.AddFilter((ISpan span) =>
            {
                // ..
                return span;
            });

到此這篇關(guān)于介紹.NET程序性能監(jiān)控系統(tǒng)Elastic AMP的使用方法的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.cnblogs.com/chenyishi/p/15597740.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品99久久 | 黄色片小视频 | 国产精品久久久久久久久久久小说 | 欧美日韩精品一区二区在线观看 | 综合久久久 | 欧美一区2区| av手机在线电影 | 亚洲免费观看 | 欧美综合视频 | 国产视频久久久久久久 | 亚洲欧美精品 | 91精品国产综合久久久久久 | 欧美成人精品高清视频在线观看 | 一区二区三区 在线 | 欧美午夜精品久久久久免费视 | 午夜爱爱毛片xxxx视频免费看 | 美色阁av| 精品久久精品久久 | ririsao久久精品一区 | 国产亚洲一区二区精品 | 亚洲国产精品网站 | 黄网免费看 | 亚洲精品久久 | 成人午夜毛片 | 97av在线 | 国产综合免费视频 | 99在线免费视频 | 中文字幕一区三级久久日本 | 精品久久久久国产 | 亚洲精品二区三区 | 日本中文字幕在线看 | 中文字幕一区二区三区四区五区 | 播放欧美一级片 | 日韩色爱| 中字精品| 久久久久久久成人 | 木耳av在线 | 激情国产| 激情图区在线观看 | yy6080久久伦理一区二区 | 精品国产精品三级精品av网址 |