大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说全网仅此一份–基于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
查看日志:
docker logs -f mssql
二、配置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
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
三、配置exporter
1、下载exporter
sqlserver的监控,需要用到第三方写的export,prometheus是开源软件提供了多种语言支持,因此有很多第三方的exporter实现。
通过这个可以找sqlserver的第三方exporter,这是一个git工程 https://github.com/awaragi/prometheus-mssql-exporter
2、部署
2.1、查看宿主机IP地址:
在安装Docker的时候,会在宿主机安装一个虚拟网关 docker0 ,我们可以使用宿主机在 docker0 上的IP地址来代替 localhost :
ip addr show docker0
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
3、测试访问
此时,本地浏览器访问 http://服务器ip:4000/metrics 可以看到 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
五、grafana配置
1、下载dashboard
在 https://grafana.com/dashboards?search=sqlserver 下载sqlserver相关的dashboard,但是上边提供的dashboard效果不一定好,可以根据需要自己配.
参考:https://grafana.com/api/dashboards/9336
2、导入json
3、展示
到这里就完成sqlserver监控了,但因为sqlserver基本是部署在winserver上,而这个第三方exporter又是容器部署的,所以这个地方还得考虑下怎么弄比较OK。后面会分享更多devops和DBA方面内容,感兴趣的朋友可以关注下!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/11866.html