av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Apache SkyWalking 監(jiān)控 MySQL Server 實(shí)戰(zhàn)解析

瀏覽:121日期:2023-03-07 14:40:48
目錄
  • 正文
  • 監(jiān)控 MySQL Server
  • 安裝過(guò)程
  • docker compose 部署

正文

Apache SkyWalking 在本月初發(fā)布了 SkyWalking Backend、UI 的 9.2.0 版本 以及 SkyWalking Java Agent 8.12.0 版本,其中就有筆者貢獻(xiàn)的 hutool-http client 5.x 插件,以后大家通過(guò) hutool 工具發(fā)送的 http 請(qǐng)求也可以出現(xiàn)在分布式鏈路中了。

另外,社區(qū)宣布計(jì)劃在 2022 年 11 月 30 日結(jié)束所有 v8 版本,v9 可以在生產(chǎn)環(huán)境中提供穩(wěn)定和更高性能的 APM,具體聲明見(jiàn) SkyWalking 官網(wǎng)。

了解 SkyWalking 的朋友都知道,它可以監(jiān)控我們的應(yīng)用程序中執(zhí)行的 SQL語(yǔ)句,監(jiān)控到的 SQL 大概像下圖這樣,看起來(lái)是不是很酷!

監(jiān)控 MySQL Server

上面展示的是在 MySQL 客戶(hù)端層面的監(jiān)控,那如果想要監(jiān)控 MySQL Server 該怎么做呢,SkyWalking 發(fā)布的 9.2.0 版本升級(jí)了許多內(nèi)容,其中一項(xiàng)就是開(kāi)始支持 MySQL Server Monitoring。

SkyWalking 是如何監(jiān)控 MySQL Server 程序的呢,SkyWalking 社區(qū)并沒(méi)有重復(fù)造輪子,而是利用了已有的開(kāi)源實(shí)現(xiàn)來(lái)采集 MySQL Server 的 metrics 數(shù)據(jù),并將 metrics 發(fā)送到 SkyWalking OAP,由 MAL 引擎去分析、計(jì)算、聚合和存儲(chǔ),具體流程如下:

1)mysqld_exporter 從 MySQL Server 收集 metrics 數(shù)據(jù);

2)OpenTelemetry Collector 通過(guò) Prometheus Receiver 從 mysqld_exporter 抓取 metrics 數(shù)據(jù);

3)OpenTelemetry Collector 通過(guò) OpenCensus gRPC Exporter 或 OpenTelemetry gRPC exporter 將 metrics 數(shù)據(jù) 發(fā)送給 SkyWalking OAP Server;

4)SkyWalking OAP Server 使用 MAL引擎解析表達(dá)式,并對(duì) metrics 數(shù)據(jù)進(jìn)行過(guò)濾、計(jì)算、聚合并存儲(chǔ)結(jié)果。

其中,mysqld_exporter 是 Prometheus 提供的用于收集 MySQL Server 的metrics 數(shù)據(jù),OpenTelemetry Collector 是 OpenTelemetry 提供的用于收集 telemetry 數(shù)據(jù),它提供了與廠(chǎng)商無(wú)關(guān)的實(shí)現(xiàn),用于接收、處理與導(dǎo)出 telemetry 數(shù)據(jù)。

安裝過(guò)程

這里假設(shè)我們已經(jīng)部署了 MySQL Server 以及 SkyWalking,現(xiàn)在想要在 SkyWalking 中監(jiān)控 MySQL Server,我們這里準(zhǔn)備一臺(tái)機(jī)器(192.168.56.102),這臺(tái)機(jī)器筆者已經(jīng)提前安裝好了 Docker,接下來(lái)我們就在這臺(tái)機(jī)器上安裝 mysqld_exporter 和 OpenTelemetry Collector 。

首先我們需要?jiǎng)?chuàng)建一個(gè) MySQL 用戶(hù)并授權(quán),用于 mysqld_exporter 收集 metrics 使用,操作如下:

create user "mysql_exporter"@"%" identified by "mysql_exporter";GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO "mysql_exporter"@"%" WITH MAX_USER_CONNECTIONS 3;flush privileges;

準(zhǔn)備 OpenTelemetry Collector 組件的配置文件 otel-collector-config.yaml

receivers:  prometheus:    config:     scrape_configs:       - job_name: "mysql-monitoring" scrape_interval: 5s static_configs:   - targets: ["mysqld-exporter:9104"]     labels:       host_name: showcaseprocessors:  batch:exporters:  otlp:    endpoint: SkyWalking OAP 地址:11800    tls:      insecure: trueservice:  pipelines:    metrics:      receivers:      - prometheus      processors:      - batch      exporters:      - otlp

對(duì)以上配置做個(gè)簡(jiǎn)要說(shuō)明:

1)receivers 用于配置 Collector 的數(shù)據(jù)來(lái)源,這里是從 prometheus 的 mysqld_exporter 抓取數(shù)據(jù);

2)exporters 用于配置要將接收到的數(shù)據(jù)發(fā)送到哪里,這里是發(fā)送到 SkyWalking OAP ;

3)processors 指定如何處理接收到的數(shù)據(jù);

4)service 配置將整個(gè) pipelines 串起來(lái)。

docker compose 部署

我們這里使用 docker compose 部署,docker-compose.yml 完整配置如下:

version: "3.8"services:  mysqld-exporter:    image: prom/mysqld-exporter:v0.14.0    container_name: mysqld-exporter    ports:      - 9104:9104    environment:      - DATA_SOURCE_NAME=mysql_exporter:mysql_exporter@(mysql地址:3306)/      - TZ=Asia/Shanghai  otel-collector:    image: otel/opentelemetry-collector:0.50.0    container_name: otel-collector    command: [ "--config=/etc/otel-collector-config.yaml" ]    volumes:      - /opt/data/otel-collector-config.yaml:/etc/otel-collector-config.yaml    expose:      - 55678

將 docker-compose.yml 和otel-collector-config.yaml 配置文件上傳到服務(wù)器并放到 /data/opt/ 目錄下,執(zhí)行 docker compose up -d 即可啟動(dòng) mysqld-exporter 和 otel-collector 服務(wù)。

啟動(dòng)完成之后,我們可以通過(guò)訪(fǎng)問(wèn) mysqld-exporter 服務(wù)http://192.168.56.102:9104/metrics 查看 mysqld-exporter 采集了 MySQL 的哪些 metrics 數(shù)據(jù),比如下圖中的 mysql_global_status_uptime 指標(biāo)表示 MySQL Server 啟動(dòng)了多長(zhǎng)時(shí)間,單位是秒。

mysqld-exporter 和 otel-collector 服務(wù)能正常采集數(shù)據(jù)之后,我們可以訪(fǎng)問(wèn) SkyWalking UI,可以查看到 MySQL Sever 端的監(jiān)控信息了。

圖中每一項(xiàng)指標(biāo)的具體含義大家可以訪(fǎng)問(wèn)官網(wǎng)查看,這里就不一一贅述了 skywalking.apache.org/docs/main/v…

剛剛演示的 SkyWalking 中 MySQL Server 的監(jiān)控功能是一名大三學(xué)生貢獻(xiàn)的!,具體貢獻(xiàn)過(guò)程可以看下issue 鏈接 github.com/apache/skyw… 。之前看到過(guò)一句話(huà),對(duì)技術(shù)有追求的開(kāi)發(fā)者都應(yīng)該去參與開(kāi)源項(xiàng)目。

相關(guān)鏈接

  • github.com/prometheus/…
  • opentelemetry.io/docs/concep…
  • skywalking.apache.org/docs/main/v…

以上就是Apache SkyWalking 監(jiān)控 MySQL Server 實(shí)戰(zhàn)解析的詳細(xì)內(nèi)容,更多關(guān)于Apache SkyWalking監(jiān)控MySQL的資料請(qǐng)關(guān)注其它相關(guān)文章!

標(biāo)簽: Linux Apache
主站蜘蛛池模板: 欧美成人一级片 | 午夜免费av | 亚洲精品一区二区三区在线 | 丁香激情网 | 黄色资源在线观看 | 日韩av网站在线观看 | 四虎色播 | 国产精品二区一区二区aⅴ污介绍 | 五月天综合网 | 黄色一级视频在线观看 | 免费的黄色大片 | www.日本黄色 | 国产精品3| 天天色影院 | 精品国产一区二 | 黄色一级免费 | 黄色激情视频在线观看 | www.97超碰 | av狠狠干| 国产又粗又猛又黄又爽无遮挡 | 亚洲一级在线 | 亚洲国产精 | 黄色精品| 午夜影院黄 | 美女免费网站 | 一区二区三区免费在线观看 | 欧洲色综合 | 色婷婷导航| 91成人精品一区在线播放 | 国产成年人视频 | 欧美不卡在线观看 | 免费av片| 日韩黄色录像 | 亚洲黄色片 | 欧美又大粗又爽又黄大片视频 | 干干干操操操 | 国产裸体永久免费视频网站 | 中文字幕亚洲欧美 | 91精品国产色综合久久不卡98 | 中文字幕系列 | 日韩欧美精品一区 |