Prometheus監控Mongodb副本集


副本集結構

10.140.10.27 主節點
10.140.10.28 從節點
10.140.10.29 仲裁節點

注意:

1、安裝mongodb_exporter可以不在仲裁節點安裝,仲裁節點設置的用戶名密碼是無法使用的,若仲裁節點沒有安裝,監控中mongodb_up是無法顯示,只會顯示主從的值

2、啟動方式建議使用第二種,第二種mongo_up可以查看主從的值,mongodb_replset_my_state=3是正常的,如果選擇第一種 mongodb_replset_my_state=4 是錯誤的,若只在一個節點執行啟動方式一的話mongodb_replset_my_state的值也是錯誤的

3、mongodb設置用戶名密碼時盡量不要使用@這個特殊符號,啟動的時候是會導致無法鏈接

4、最好是單獨設置一個監控的用戶名密碼指定admin庫 試過指定對應的庫未成功

安裝golang

yum -y install golang

編輯環境變量並生效

export GOROOT=/usr/lib/golang
export GOPATH=/usr/local/golang
export PATH=$PATH:$GOROOT/bin
source /etc/profile

創建目錄

mkdir /usr/local/golang

安裝插件

go get github.com/Masterminds/glide
go install github.com/Masterminds/glide
cd $GOPATH/src/github.com/Masterminds/glide
go build
cp glide /usr/local/bin

安裝mongodb_exporter

git clone https://github.com/dcu/mongodb_exporter.git  $GOPATH/src/github.com/dcu/mongodb_exporter

cd $GOPATH/src/github.com/dcu/mongodb_exporter

make build

成功后,出現這個命令

[root@test mongodb_exporter]# ll
total 10672
drwxr-xr-x 3 root root     4096 Sep  8 16:48 collector
-rw-r--r-- 1 root root      516 Sep  8 16:48 Dockerfile
-rw-r--r-- 1 root root     1472 Sep  8 16:48 glide.lock
-rw-r--r-- 1 root root      358 Sep  8 16:48 glide.yaml
drwxr-xr-x 2 root root       28 Sep  8 16:48 grafana_dashboards
-rw-r--r-- 1 root root    35252 Sep  8 16:48 groups.yml
-rw-r--r-- 1 root root     1082 Sep  8 16:48 LICENSE
-rw-r--r-- 1 root root      783 Sep  8 16:48 Makefile
-rwxr-xr-x 1 root root 10846790 Sep  8 16:48 mongodb_exporter
-rw-r--r-- 1 root root     8123 Sep  8 16:48 mongodb_exporter.go
-rw-r--r-- 1 root root     4683 Sep  8 16:48 README.md
drwxr-xr-x 2 root root       37 Sep  8 16:48 screenshots
drwxr-xr-x 2 root root      111 Sep  8 16:48 shared
drwxr-xr-x 2 root root       79 Sep  8 16:48 snap
drwxr-xr-x 4 root root       40 Sep  8 16:48 vendor

第一種方式啟動

分別在主從節點執行此命令
cd /usr/local/golang/src/github.com/dcu/mongodb_exporter .
/mongodb_exporter -mongodb.uri mongodb://10.140.10.27:27017,10.140.10.28:27017

 第二種方式啟動

啟動主節點
cd /usr/local/golang/src/github.com/dcu/mongodb_exporter
./mongodb_exporter -mongodb.uri mongodb://10.140.10.27:27017
啟動從節點
cd /usr/local/golang/src/github.com/dcu/mongodb_exporter
./mongodb_exporter -mongodb.uri mongodb://10.140.10.28:27017

啟動腳本

cp /usr/local/golang/src/github.com/dcu/mongodb_exporter/mongodb_exporter  /usr/local/bin
cat /etc/init.d/mongodb_exporter
#!/bin/bash IP=`ip addr | grep -v virbr |grep -o -e 'inet [0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}.[0-9]\{1,3\}'|grep -v "127.0.0"|awk '{print $2}'` PORT=27017 COMMAND=/usr/local/bin/mongodb_exporter SERVER=mongodb_exporter USER=txkj PASSWORD=123456 PIDNUM=`pidof $SERVER` start(){ if [ -z "$PIDNUM" ];then $COMMAND -mongodb.uri mongodb://$USER:$PASSWORD@$IP:$PORT >/dev/null 2>&1 & echo "Now,the server has runing" else echo "$0 is running" fi } stop(){ if [ -z "$PIDNUM" ];then echo "$0 is not running" else echo "shutting down $0" kill -9 "$PIDNUM" && echo "PID $PIDNUM was killed." fi } status(){ if [[ -z "$PIDNUM" ]];then echo "$0 is not runing" else echo "$0 is runing,it's PID is $PIDNUM" fi } case $1 in start) start ;; stop) stop ;; status) status ;; restart) stop start ;; *) echo "Usage:$0 {start|stop|status|restart}" ;; esac
添加執行權限
chmod +x /etc/init.d/mongodb_exporter

檢測

curl http://10.140.10.27:9001/metrics

到此,mongodb_exporter部署完成了,現在開始修改peometheus的配置文件

- job_name: 'mongodb-Rep'
    static_configs:
    - targets: ['10.140.10.27:9001']
      labels:
        instance: 10.140.10.27
    - targets: ['10.140.10.28:9001']
      labels:
        instance: 10.140.10.28


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM