全网仅此一份–基于prometheus+grafana监控sqlserver数据库「建议收藏」

全网仅此一份–基于prometheus+grafana监控sqlserver数据库「建议收藏」概述目前网上没有发现prometheus监控sqlserver数据库的相关教程,而生产环境有sqlserver数据库,领导也要求监控下来,这里简

概述

目前网上没有发现prometheus监控sqlserver数据库的相关教程,而生产环境有sqlserver数据库,领导也要求监控下来,这里简单写一下监控的过程。


一、模拟sqlserver环境

docker run -e ACCEPT_EULA=Y -e SA_PASSWORD=qkD4x3yy -p 1433:1433 --name mssql -d microsoft/mssql-server-linux
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

查看日志:

docker logs -f mssql
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」


二、配置node环境

由于mssql-exporter是用nodejs开发的,所以首先准备一个node环境。

下载地址:http://nodejs.org

1、下载并解压

wget https://nodejs.org/dist/v10.16.3/node-v10.16.3-linux-x64.tar.xz
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

2、解压

tar -xvf node-v10.16.3-linux-x64.tar.xz 

3、配置环境变量

echo "export PATH=$PATH:/prometheus/package/node-v10.16.3-linux-x64/bin" >> /etc/profile
source /etc/profile

4、测试

验证一下是否成功

node --version
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」


三、配置exporter

1、下载exporter

sqlserver的监控,需要用到第三方写的export,prometheus是开源软件提供了多种语言支持,因此有很多第三方的exporter实现。

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

通过这个可以找sqlserver的第三方exporter,这是一个git工程 https://github.com/awaragi/prometheus-mssql-exporter

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

2、部署

2.1、查看宿主机IP地址:

在安装Docker的时候,会在宿主机安装一个虚拟网关 docker0 ,我们可以使用宿主机在 docker0 上的IP地址来代替 localhost :

ip addr show docker0
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

2.2、部署exporter

Docker容器运行的时候有 host 、 bridge 、 none 三种网络可供配置。默认是 bridge ,即桥接网络,以桥接模式连接到宿主机; host 是宿主网络,即与宿主机共用网络; none 则表示无网络,容器将无法联网。

--使用宿主机IP
docker run -e SERVER=172.17.0.1 -e USERNAME=SA -e PASSWORD=qkD4x3yy -e DEBUG=app -p 4000:4000 \
--name mssql-exporter awaragi/prometheus-mssql-exporter
​
--使用host网络(测试不成功)
docker run -e SERVER=其他主机 -e USERNAME=SA -e PASSWORD=密码 -e DEBUG=app --network host \
--name mssql-exporter2 awaragi/prometheus-mssql-exporter
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

3、测试访问

此时,本地浏览器访问 http://服务器ip:4000/metrics 可以看到 sqlserver相关的所有监控指标列表。

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」


四、关联Prometheus

Prometheus 和sqlserver_exporter 服务都已经启动起来了,那么接下来就需要将二者关联起来,让 Prometheus 来定时抓取 Exporter 提供的数据。我们需要修改 Prometheus 的配置文件 prometheus.yml 增加 sqlserver 相关 exporter job。

说明一下:增加了一个 job_name 为sqlserver 的任务,targets 为指向 sqlserver_exporter 提供的 Http 接口服务,labels 为该 job 配置一个标签,方便下边 Grafana 页面显示

- job_name: sqlserver
 static_configs:
 - targets: ['172.16.10.123:4000']
 labels:
 instance: sqlserver_test

重启容器,隔一会查看metris:http://172.16.10.123:9091/targets

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」


五、grafana配置

1、下载dashboard

在 https://grafana.com/dashboards?search=sqlserver 下载sqlserver相关的dashboard,但是上边提供的dashboard效果不一定好,可以根据需要自己配.

参考:https://grafana.com/api/dashboards/9336
全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

2、导入json

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

3、展示

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」


到这里就完成sqlserver监控了,但因为sqlserver基本是部署在winserver上,而这个第三方exporter又是容器部署的,所以这个地方还得考虑下怎么弄比较OK。后面会分享更多devops和DBA方面内容,感兴趣的朋友可以关注下!

全网仅此一份--基于prometheus+grafana监控sqlserver数据库「建议收藏」

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/11866.html

(0)

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注