监控神器-普罗米修斯Prometheus的安装

监控神器-普罗米修斯Prometheus的安装  最近看了些AIOPS的资料,对于里面提及的一个普罗米修斯Prometheus起了兴趣,首先是联想到异形,哈哈。去看了一下,普罗米修斯还真是厉害,而且还是开源的,真是搬砖党的福音。功能:在业务层用作埋点系统Prometheus支持多种语言(Go,java,python,ruby官方提供客户端,其他语言有第三方开源客户端)。我们可以通过客户端方面的对核心业务进行埋点。如下单流程、添加购…

大家好,又见面了,我是你们的朋友全栈君。

   最近看了些AIOPS的资料,对于里面提及的一个普罗米修斯Prometheus起了兴趣,首先是联想到异形,哈哈。去看了一下,普罗米修斯还真是厉害,而且还是开源的,真是搬砖党的福音。

功能:

  • 在业务层用作埋点系统

Prometheus支持多种语言(Go,java,python,ruby官方提供客户端,其他语言有第三方开源客户端)。我们可以通过客户端方面的对核心业务进行埋点。如下单流程、添加购物车流程。

  • 在应用层用作应用监控系统

一些主流应用可以通过官方或第三方的导出器,来对这些应用做核心指标的收集。如redis,mysql

  • 在系统层用作系统监控
    除了常用软件, prometheus也有相关系统层和网络层exporter,用以监控服务器或网络。
  • 集成其他的监控
    prometheus还可以通过各种exporte,集成其他的监控系统,收集监控数据,如AWS CloudWatch,JMX,Pingdom等等

Prometheus架构:

prometheus是一个用Go编写的时序数据库,可以支持多种语言客户端,架构如下:

监控神器-普罗米修斯Prometheus的安装

下面说一下这个开源软件的安装实践过程,目标如下:

  1. 安装go 语言环境
  2. 在监控服务器上安装prometheus
  3. 在被监控环境上安装export
  4. 安装grafana

具体安装过程如下:

步骤1:安装go 语言环境

由于Prometheus 是用golang开发的,所以首先安装一个go环境,Go语言是跨平台,支持Windows、Linux、Mac OS X等系统,还提供有源码,可编译安装

Windows :go1.8.3.windows-amd64.msi (78MB)

Linux :go1.8.3.linux-amd64.tar.gz (86MB)

Mac :go1.8.3.darwin-amd64.tar.gz (85MB)   (推荐)

Source: go1.8.3.src.tar.gz (15MB)

由于国内需要翻墙:所以我是通过某些国内资源下载的:https://download.csdn.net/download/cuipuke/10048498

下载后,上传到要部署的服务器(部署服务器和外网隔离,所以转了一道)。解压缩然后修改配置文件

[root@archive soft]# tar -C /usr/local -xzf go1.8.3.linux-amd64.tar.gz

[root@archive soft]# vim  /etc/profile

在文件的最后添加如下内容:

export PATH=$PATH:/usr/local/go/bin

保存退出后,接着让配置文件立刻生效:

[root@archive aiops]# source  /etc/profile

验证一下是否成功,用go version 来验证

[root@archive aiops]# go  version

go version go1.8.3 linux/amd64

监控神器-普罗米修斯Prometheus的安装

步骤2:在监控服务器上安装prometheus

开始安装prometheus,首先先去官网下载对应系统的版本:https://prometheus.io/download/,如下图:

监控神器-普罗米修斯Prometheus的安装

 

下载后上传到部署的服务器,在服务上执行如下命令解压(root用户,解压到 /usr/local):

tar  -vxf  prometheus-2.3.2.linux-amd64.tar.gz  -C /usr/local/

监控神器-普罗米修斯Prometheus的安装

为了以后进入目录方便,做了一个软连接:

ln  -sv  /usr/local/prometheus-2.3.2.linux-amd64/  /usr/local/Prometheus

接着要配置一下监控的配置文件:prometheus.yml

监控神器-普罗米修斯Prometheus的安装

配置完成后,只需要运行起来这个软件:

[root@archive prometheus]# ./prometheus

监控神器-普罗米修斯Prometheus的安装

通过如下URL可以打开prometheus的自带监控界面: IP:9090,点击targets 跳转到监控目标,这里展现了多个监控对象。红框的表示部署的prometheus

监控神器-普罗米修斯Prometheus的安装

说明:上图中117 显示蓝色是因为,117已经安装了export,其他未安装的显示为红色。

步骤3:在系统层用作系统监控exporter

以在159这台主机为例,安装exporter ,这台linux环境是centos,因此用的监控export是node_exporter-0.16.0.linux-amd64.tar.gz  ,首先在官网下载这个文件,然后上传到被监控的主机(作为部署服务的主机上也需要安装 export),因此下载并部署后,执行如下命令:

tar xvf node_exporter-0.16.0.linux-amd64.tar.gz -C /usr/local/

nohup /usr/local/node_exporter-0.16.0.linux-amd64/node_exporter &

执行后,我们回到prometheus查看监控目标,可以看到159主机也显示为蓝色了。

监控神器-普罗米修斯Prometheus的安装

启动后,可以看到159主机已经变成蓝色,正常up 状态。其他几台116,117,118 主机也通过先安装go环境,再安装export的方式,进行监控起来。

         接下来说一下oracle主机115的监控,Oracle的监控,需要用到第三方写的export。prometheus是开源软件提供了多种语言支持,因此有很多第三方的exporter实现,https://prometheus.io/docs/instrumenting/exporters/ 官网这里有介绍一些第三方的链接:

监控神器-普罗米修斯Prometheus的安装

 

通过这个可以找oracle的第三方exporter,这是一个git工程https://github.com/iamseth/oracledb_exporter

监控神器-普罗米修斯Prometheus的安装

 

这里面,找到

监控神器-普罗米修斯Prometheus的安装

         通过releases找到适合自己的版本,我直接用的是二进制文件,图中执行这里标红色,参数语法有问题,具体应该如下:

        ./oracledb_exporter.linux-amd64 -log.level error -web.listen-address IP:9161

下面看一下具体情况:

上传下面文件到部署的服务器(需要有安装oracle客户端,这样才能连的上数据库,这里因为已经安装了oracle客户端,略了客户端安装)

 [oracle@localhost soft]$ ls  -ltr

总用量 93296

-rw-r–r– 1 oracle dba 90029041 9月   5 13:57 go1.8.3.linux-amd64.tar.gz

-rwxr-xr-x 1 oracle dba  5502288 9月   5 13:57 oracledb_exporter.linux-amd64

1、首先安装go 环境,与上面相同,这里略过

2、接着将二进制文件运行起来,步骤如下:

修改执行权限

[root@localhost soft]# chmod +x  oracledb_exporter.linux-amd64

再设置执行的环境变量,命令行直接执行如下命令export:

export DATA_SOURCE_NAME=用户名/密码@ 数据库服务名

启动服务

./oracledb_exporter.linux-amd64 -log.level error -web.listen-address IP:9161

 

监控神器-普罗米修斯Prometheus的安装

步骤4:给prometheus换一个面板

 

下面给监控换一个dashboard,这里用的是grafana,下载地址https://grafana.com/grafana/download

监控神器-普罗米修斯Prometheus的安装

 

如果部署的服务器可以联网可以直接执行下面命令:

wget https://s3-us-west-2.amazonaws.com/grafana-releases/release/grafana-5.2.3-1.x86_64.rpm 
sudo yum localinstall grafana-5.2.3-1.x86_64.rpm 

如果不能,只能先下载再部署。rpm包的安装也很简单,执行如下命令

[root@archive soft]# rpm  -i  grafana-5.2.3-1.x86_64.rpm

接着把grafana加入到系统服务,将服务启动

[root@archive soft]# sudo /sbin/chkconfig –add grafana-server

[root@archive soft]#  sudo service grafana-server start

Starting Grafana Server: …

启动后,打开如下URL,端口采用默认的3000,http://10.1.4.159:3000/

监控神器-普罗米修斯Prometheus的安装

输入默认的admin/admin

进去后会要求修改密码,然后点击add datasource,选中 Prometheus 2.0 Stats后,就可以呈现如下的监控面板了:

监控神器-普罗米修斯Prometheus的安装

有同事说比较丑。好吧,美丑自在人心,哈哈。

 

 

 

 

 

 

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143983.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言全局变量和局部变量的区别的代码_函数的形参都属于全局变量

    c语言全局变量和局部变量的区别的代码_函数的形参都属于全局变量局部变量和全局变量的区别背景:上午看书阅及这两对概念,有很多相似之处,故记之。一.局部变量&全局变量1局部变量:“在函数内定义的变量”,即在一个函数内部定义的变量,只在本函数范围内有效。2全局变量:“在函数外定义的变量”,即从定义变量的位置到本源文件结束都有效。目的:增加函数间数据联系的渠道。由于同一文件中的所有函数都能引用全局变量的值,因此如果在一个函数中改变了全局变…

    2025年8月3日
    3
  • dcgan(bigbang)

    来源:https://github.com/aymericdamien/TensorFlow-Examples#tutorials”””DeepConvolutionalGenerativeAdversarialNetwork(DCGAN).Usingdeepconvolutionalgenerativeadversarialnetworks(DCGAN)toge…

    2022年4月11日
    35
  • 常用快捷键大全「建议收藏」

    常用快捷键大全「建议收藏」一、系统快捷键F1帮助F2改名F3搜索F4地址F5刷新F6切换F8安全模式F10菜单F11全屏INS插入模式PRTSCSYSRQ截屏CAPSLOCK大写字母锁定DELETE

    2022年8月3日
    4
  • 501,502,503,504的区别_412状态码

    501,502,503,504的区别_412状态码502badgateway顾名思义网关错误后端服务器tomcat没有起来,应用服务的问题(前提是接入层7层正常的情况下)。应用服务问题一种是应用本身问题;另一种是因为依赖服务问题比如依赖服务RT高,依赖的服务有大的读取(mysql慢查,http等),以至于调用方超过超时read时间;服务集群压力大时,也会出现502超时(502理解为不可响应或响应不过来,其实还是不可响应)。504…

    2022年4月19日
    251
  • 微型计算机及其接口技术

    微型计算机及其接口技术一.微机总线微机中总线一般有内部总线:是微机内部各外围芯片与处理器之间的总线,用于芯片一级的互连系统总线:是微机中各插件板与系统板之间的总线,用于插件板一级的互连1.ISA(industria

    2022年7月1日
    20
  • CentOS8 Docker 端口映射

    CentOS8 Docker 端口映射概念端口映射:端口映射就是将内网中的主机的一个端口映射到外网主机的一个端口,提供相应的服务。当用户访问外网IP的这个端口时,服务器自动将请求映射到对应局域网内部的机器上。例:我们在内网中有一台Web服务器,但是外网中的用户是没有办法直接访问该服务器的。于是我们可以在路由器上设置一个端口映射,只要外网用户访问路由器ip的80端口,那么路由器会把自动把流量转到内网Web服务器的80端口上。使用使用:dockerrun–namecontainer-name:tag-d-p服务器端口:Doc

    2022年10月18日
    2

发表回复

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

关注全栈程序员社区公众号