prometheus監控es,同樣采用exporter的方案。
項目地址:
elasticsearch_exporter:https://github.com/justwatchcom/elasticsearch_exporter
1、安裝部署
現有es三節點的集群,環境大概如下:
主機 | 組件 |
192.168.75.11 | prometheus |
192.168.75.21 | es,kibana,nginx |
接着分別在如上三台主機上進行如下配置:
wget https://github.com/justwatchcom/elasticsearch_exporter/releases/download/v1.1.0/elasticsearch_exporter-1.1.0.linux-amd64.tar.gz tar -zxv -f elasticsearch_exporter-1.1.0.linux-amd64.tar.gz mv elasticsearch_exporter-1.1.0.linux-amd64 /usr/local/elasticsearch_exporter
創建用戶等
groupadd prometheus useradd -g prometheus -m -d /var/lib/prometheus -s /sbin/nologin prometheus chown -R prometheus.prometheus /usr/local/elasticsearch_exporter
啟動監控客戶端:
nohup ./elasticsearch_exporter --web.listen-address ":9308" --es.uri http://192.168.75.21:9200 &
使用systemd管理:
cat /lib/systemd/system/es_exporter.service [Unit] Description=The es_exporter After=network.target [Service] Type=simple User=prometheus ExecStart=/usr/local/elasticsearch_exporter/elasticsearch_exporter --web.listen-address ":9308" --es.uri http://192.168.75.21:9200 Restart=on-failure [Install] WantedBy=multi-user.target
啟動:
systemctl daemon-reload
systemctl start es_exporter
systemctl enable es_exporter
查看metrics:
curl 127.0.0.1:9308/metrics
2、配置 prometheus.yml 添加監控目標
vim /usr/local/prometheus/prometheus.yml - job_name: 'elasticsearch' scrape_interval: 60s scrape_timeout: 30s metrics_path: "/metrics" static_configs: - targets: ['192.168.75.21:9308'] labels: service: elasticsearch
重啟服務。
systemctl restart prometheus
或者通過命令熱加載:
curl -XPOST localhost:9090/-/reload
3、配置 Grafana 的模板
模板通過json文件進行導入,文件就在解壓的包內。
參考地址:https://shenshengkun.github.io/posts/550bdf86.html
或者通過如下ID進行導入:2322
以及其他。
4、開啟認證的啟動方式
如果es開啟了認證,那么啟動的時候需要將用戶名密碼加載進去:
elasticsearch_exporter --web.listen-address ":9308" --es.uri http://username:password@192.168.75.21:9200 &
其中使用的是monitoring
的用戶密碼。
當然,除去這種命令行的啟動方式之外,還可以像上邊一樣,基於systemd進行管理,只需將認證的參數信息寫入到如下內容當中:
參考網址:https://github.com/justwatchcom/elasticsearch_exporter
cat /etc/default/elasticsearch_exporter [Unit] Description=The es_exporter After=network.target [Service] Type=simple User=prometheus ExecStart=/usr/local/elasticsearch_exporter/elasticsearch_exporter --web.listen-address ":9308" --es.uri=http://username:password@192.168.75.21:9200 Restart=on-failure [Install] WantedBy=multi-user.target