Bài viết hướng dẫn cài đặt vmware_exporter để giám sát máy chủ VMware ESXi bằng Prometheus và Grafana.
Cài đặt vmware_exporter trên ubuntu.
Các bước triển khai:
Trước khi cài đặt vmware_exporter, để đảm bảo an toàn cần tạo tài khoản monitor (Read-Only) trên máy chủ Esxi, các bước thực hiện như sau:
Đăng nhập vào ESXi qua trình duyệt, ở phần Host > Chọn Manage > Security & users > Users > Add user
data:image/s3,"s3://crabby-images/3ab89/3ab89081f1bc35160f311bc4edc4f82d976963cc" alt=""
Chọn lại Host > Actions > Permissions
data:image/s3,"s3://crabby-images/e51af/e51afdad93d859a09f4f0359f6149b7ca8eb6187" alt=""
Chọn user monitor > Read-only > Add user
data:image/s3,"s3://crabby-images/47283/47283c287b7d84ce83d87841042db655dd6f2494" alt=""
Như vậy là đã tạo xong user monitor.
Cài đặt các công cụ và thư viện cần thiết để chuẩn bị cho việc sử dụng vmware_exporter:
sudo apt update -y
sudo apt install python3 curl net-tools git wget python3-pip -y
Cài đặt thư viện PyYAML cho python 3, cho phép làm việc với dữ liệu YAML trong python:
sudo pip3 install --ignore-installed PyYAML
Cài đặt vmware_exporter qua pip3
pip3 install vmware_exporter
Tìm kiếm thư mục chứa file config của vmware_exporter bằng lệnh sau:
find / -name "vmware_exporter"
data:image/s3,"s3://crabby-images/10882/108829df7372910606cf14ce8fc5f7ed1fdcdae8" alt=""
Sau khi đã có đường dẫn chứa file config của vmware_exporter, tiến hành cấu hình:
nano /home/hoangits/.local/lib/python3.12/site-packages/vmware_exporter/config.yml
Nội dung file:
default:
vsphere_host: 10.0.150.10
vsphere_user: 'monitor'
vsphere_password: 'Abc@123'
ignore_ssl: True
specs_size: 5000
fetch_custom_attributes: True
fetch_tags: True
fetch_alarms: True
collect_only:
vms: True
vmguests: True
datastores: True
hosts: True
snapshots: True"
Dưới đây là mô tả ý nghĩa của các thông số trong cấu hình mẫu:
vsphere_host
: Địa chỉ IP hoặc tên miền của máy chủ vSphere ESXi hoặc vCenter.vsphere_user
: Tên người dùng để đăng nhập vào máy chủ vSphere.vsphere_password
: Mật khẩu tương ứng với người dùng trên máy chủ vSphere.ignore_ssl
: Có bỏ qua chứng chỉ SSL không. Nếu đặt làTrue
, vmware_exporter sẽ bỏ qua các lỗi chứng chỉ SSL không hợp lệ.specs_size
: Kích thước tối đa của các yêu cầu API khi lấy thông tin về máy ảo và máy chủ.fetch_custom_attributes
: Xác định liệu có thu thập thông tin thuộc tính tùy chỉnh từ máy ảo không.fetch_tags
: Xác định liệu có thu thập thông tin về nhãn từ máy ảo không.fetch_alarms
: Xác định liệu có thu thập thông tin về cảnh báo từ máy chủ không.collect_only
: Xác định các loại đối tượng sẽ được thu thập thông tin, bao gồmvms
,vmguests
,datastores
,hosts
, vàsnapshots
.
Nếu có nhiều Esxi thì thêm nhiều đoạn cấu hình như trên, thay <default:> thành tên qui định cho mỗi ESXi.
Tạo service cho vmware_exporter để systemd quản lý:
sudo nano /etc/systemd/system/vmware_exporter.service
Nội dung file:
[Unit]
Description=VMWare Exporter
Wants=network-online.target
After=network-online.target
[Service]
User=hoangits
Group=hoangits
Type=simple
ExecStart=/usr/bin/python3 /home/hoangits/.local/bin/vmware_exporter -c /home/hoangits/.local/lib/python3.12/site-packages/vmware_exporter/config.yml
Restart=always
[Install]
WantedBy=multi-user.target
Cập nhật dịch vụ mới bằng lệnh systemctl daemon-reload sau đó khởi động vmware_exporter
và bật tính năng tự khởi động theo OS cho nó.
sudo systemctl daemon-reload
sudo systemctl start vmware_exporter
sudo systemctl enable vmware_exporter
sudo systemctl status vmware_exporter
Kết quả như sau:
data:image/s3,"s3://crabby-images/7c9dc/7c9dc17143dbef6fddc3b1af45db267bdb599363" alt=""
Kiểm tra xem port đã chạy chưa:
netstat -tlnp | grep 9272
data:image/s3,"s3://crabby-images/48b5b/48b5b7a1f24d80325421aefbc3ed311d13e364e1" alt=""
Truy cập URL của Host cùng port 9272 để kiểm tra: http://<ipaddr>:9272/metrics
data:image/s3,"s3://crabby-images/2abe5/2abe5d2033ab6a67ccbdc84d6f56bdca1f0d5e36" alt=""
Khai báo targer cho Prometheus để thu thập metrics từ vmware_exporter
sudo nano /etc/prometheus/prometheus.yml
Nội dung cấu hình:
- job_name: 'ESXi10'
metrics_path: '/metrics'
static_configs:
- targets:
- 10.0.150.10
labels:
hostname: ESXi10
device: VMWARE
params:
section: [default]
relabel_configs:
- source_labels: [__address__]
target_label: __param_target
- source_labels: [__param_target]
target_label: instance
- target_label: __address__
replacement: 10.0.150.79:9272
- source_labels: [hostname]
target_label: host_name
data:image/s3,"s3://crabby-images/597fd/597fd685354cb1a065dbe2568f94821677b3f690" alt=""
Khi có nhiều ESXi cần giám sát thì thêm nhiều job
Chạy lệnh kiểm tra tệp cấu hình Prometheus:
promtool check config /etc/prometheus/prometheus.yml
data:image/s3,"s3://crabby-images/ea135/ea1353c4b1b45114c931beb8413bd7e76cbf2fcb" alt=""
Khởi động lại và kiểm tra dịch vụ prometheus:
sudo systemctl restart prometheus
sudo systemctl status prometheus
data:image/s3,"s3://crabby-images/7c1c9/7c1c961586ceb9242566c17970a1c520fa1cf0de" alt=""
Trên WebUI của prometheus, chọn Status > Target health
Thông tin target Vmware đã được hiển thị
data:image/s3,"s3://crabby-images/1dfbe/1dfbe5be8629deb81cde095761fd93a67186c1f8" alt=""
Tiếp tục thêm Dashboard vào Grafana để giám sát. Có thể tự tạo Dashboard theo nhu cầu cần giám sát hoặc thêm dashboard có sẵn.
Truy cập trang https://grafana.com/grafana/dashboards/ và tìm dashboard cho vmware_exporter:
Mình tìm thấy 1 dashboard sử dụng data source cho Prometheus, chọn vào Dashboard > Tìm đến phần Get this dashboard > Copy ID to the clipboard
data:image/s3,"s3://crabby-images/77819/7781940eb4bd454f58b8c4cae630136b2f3ba33e" alt=""
Truy cập vào Grafana http://<ipaddr>:3000
Chọn vào mục Dashboard > New > Import
data:image/s3,"s3://crabby-images/50038/500380f682c3146e6530f35a875abd1c3f22aeea" alt=""
Paste ID vừa copy vào > Load
data:image/s3,"s3://crabby-images/9edcc/9edcc953c28d44352bedb519cc191edbbdff9bd8" alt=""
Đặt tên và chọn Datasource là Prometheus > Import
data:image/s3,"s3://crabby-images/7df0b/7df0b20f8c57a886d60b23267d81de94eeeb2813" alt=""
Đến đây chúng ta đã có cơ bản 1 Dashboard. Điều bạn cần làm là điều chỉnh lại các Query và metrics để có được Dashboard hoàn chỉnh.
data:image/s3,"s3://crabby-images/8c5b2/8c5b2a71da818e4dbe5d5f01db53aab4979588ba" alt=""