从零开始搭建prometheus

本文将从零开始,逐步教你如何搭建Prometheus监控系统。首先进行搭建准备,创建必要的目录,然后安装Prometheus Server,并配置启动。接着安装Go环境,以便后续操作。再安装客户端并提供metrics接口,通过Node Exporter来获取节点指标。最后,介绍了如何更新Prometheus配置并查看监控效果。
摘要由CSDN通过智能技术生成

搭建prometheus

搭建准备

mkdir -p /home/menglinhai/promethues
mkdir -p /home/menglinhai/promethues/server
mkdir -p /home/menglinhai/promethues/client
touch /home/menglinhai/promethues/server/rules.yml
chmod 777 /home/menglinhai/promethues/server/rules.yml

安装Prometheus Server

  1. mkdir -p /home/menglinhai/promethues/server/
  2. touch /home/menglinhai/promethues/server/prometheus.yml
  3. 改变权限为 chmod 777 /home/menglinhai/promethues/server/prometheus.yml
global:
  scrape_interval:     15s # 默认抓取间隔, 15秒向目标抓取一次数据。
  external_labels:
    monitor: 'codelab-monitor'
# 这里表示抓取对象的配置
scrape_configs:
    #这个配置是表示在这个配置内的时间序例,每一条都会自动添加上这个{job_name:"prometheus"}的标签  - job_name: 'prometheus'
    scrape_interval: 5s # 重写了全局抓取间隔时间,由15秒重写成5秒
    static_configs:
      - targets: ['localhost:9090']

运行命令行

docker rm -f prometheus
docker run --name=prometheus -d \
-p 9090:9090 \
-v /home/menglinhai/promethues/server/prometheus.yml:/etc/prometheus/prometheus.yml \
-v /home/menglinhai/promethues/server/rules.yml:/etc/prometheus/rules.yml \
prom/prometheus:v2.7.2 \
--config.file=/etc/prometheus/prometheus.yml \
--web.enable-lifecycle

访问192.168.152.128:9090 观看web端展示
访问192.168.152.128:9090/metrics 访问,默认prometheus会抓取自己的/metrics接口

go环境安装

若没有go环境可以安装配置go环境

yum -y install wget git
wget -c https://studygolang.com/dl/golang/go1.10.3.linux-amd64.tar.gz
tar -C /opt/ -zxvf go1.10.3.linux-amd64.tar.gz
#设置环境变量
vim ~/.bash_profile
#添加以下内容
export GOROOT=/opt/go
export PATH=$PATH:$GOROOT/bin
export GOPATH=/home/menglinhai/promethues/client/golang/

安装客服端,提供metics接口

mkdir -p /home/menglinhai/promethues/client/golang/src
cd !$
export GOPATH=/home/menglinhai/promethues/client/golang/
#克隆项目
git clone https://github.com/prometheus/client_golang.git
#安装需要FQ的第三方包
mkdir -p $GOPATH/src/golang.org/x/
cd !$
git clone https://github.com/golang/net.git
git clone https://github.com/golang/sys.git
git clone https://github.com/golang/tools.git
#安装必要软件包
go get -u -v github.com/prometheus/client_golang/prometheus
#编译
cd $GOPATH/src/github.com/prometheus/client_golang/examples/random/
go build -o random main.go
./random -listen-address=:8080 &
./random -listen-address=:8081 &
./random -listen-address=:8082 &

通过node exporter提供metrics

docker run -d \
--name=node-exporter \
-p 9100:9100 \
prom/node-exporter

更改/home/menglinhai/promethues/server/prometheus.yml 文件 重新载入配置curl -X POST http://localhost:9090/-/reload

global:
  scrape_interval:     15s # 默认抓取间隔, 15秒向目标抓取一次数据。
  external_labels:
    monitor: 'codelab-monitor'
rule_files:
  #- 'prometheus.rules'
# 这里表示抓取对象的配置
scrape_configs:
  #这个配置是表示在这个配置内的时间序例,每一条都会自动添加上这个{job_name:"prometheus"}的标签  - job_name: 'prometheus'
  - job_name: 'prometheus'
    scrape_interval: 5s # 重写了全局抓取间隔时间,由15秒重写成5秒
    static_configs:
      - targets: ['localhost:9090']
      - targets: ['http://192.168.152.128:8080', 'http://192.168.152.128:8081','http://192.168.152.128:8082']
        labels:
          group: 'client-golang'
      - targets: ['http://192.168.152.128:9100']
        labels:
          group: 'client-node-exporter'

prometheus还提供了各种exporter工具,地址为 点击这里

观看192.168.152.128:9090 链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值