dbnetlib sqlserver不存在或拒绝访问_全网仅此一份--基于prometheus+grafana监控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
ed3f6871e099cbe615e7a5c715657b46.png

查看日志:

docker logs -f mssql
1018bc82ee2b8167bbe1578c319c2b39.png

二、配置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
e335b85a456d7854ed8524d6f07f6e87.png

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/profilesource /etc/profile

4、测试

验证一下是否成功

node --version
a8c84262fdce2a5e5319257c65cf5947.png

三、配置exporter

1、下载exporter

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

712673e55bcabcd3afaa565ebf1c1925.png

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

099806ea7fe7e0d8f94aac7463688f35.png

2、部署

2.1、查看宿主机IP地址:

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

ip addr show docker0
e2bba563a13d3dd6816c2c2bc3208bf8.png

2.2、部署exporter

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

--使用宿主机IPdocker 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
33b0b1214826b166ec2f81933f1476b9.png

3、测试访问

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

1ac0ac616054a79a4a1143948e7ecbfc.png

四、关联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

09daa4f1dff14cee2e0237033d1579d6.png

五、grafana配置

1、下载dashboard

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

参考:https://grafana.com/api/dashboards/9336
4ee748e95bb5a9addf7912710b7d8000.png

2、导入json

dfb309defd98b30c314dfbaa5533a610.png

3、展示

bc4da9287887ccd5e3864f9fd0cd50a8.png
a280e581e5bdb74359378be202b87b3b.png
70d9199ed746280cb478a61aaf322194.png
6416a707c45115a5f96415065ad482af.png

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

54b77526fdc31cf1fa15248a6cb8956b.png
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值