Sunday, January 19, 2025

Làm thế nào để Monitor PostgreSQL trên Ubuntu 20.04 với Prometheus và Grafana

-

1. Tổng quan.

PostgreSQL với Grafana và Prometheus là một giải pháp để giám sát và trực quan hóa dữ liệu từ hệ thống cơ sở dữ liệu PostgreSQL bằng cách sử dụng công cụ Grafana và nền tảng giám sát Prometheus.

  • PostgreSQL là một hệ thống quản lý cơ sở dữ liệu mã nguồn mở được sử dụng rộng rãi và phổ biến. Nó cung cấp các tính năng mạnh mẽ và đáng tin cậy cho việc lưu trữ và truy vấn dữ liệu.
  • Prometheus là một nền tảng giám sát mã nguồn mở được thiết kế để thu thập, lưu trữ và truy xuất các metric từ các hệ thống và ứng dụng khác nhau. Nó hỗ trợ việc giám sát thời gian thực và cung cấp các công cụ phân tích và cảnh báo mạnh mẽ.
  • Grafana là một công cụ trực quan hóa dữ liệu và tạo bảng điều khiển đa nguồn dữ liệu. Nó cung cấp giao diện người dùng tương tác và linh hoạt để tạo biểu đồ, bảng điều khiển và báo cáo dựa trên dữ liệu từ nhiều nguồn, bao gồm Prometheus.

Khi kết hợp PostgreSQL, Grafana và Prometheus lại với nhau, bạn có thể thu thập và lưu trữ các metric từ PostgreSQL bằng Prometheus và sử dụng Grafana để trực quan hóa và hiển thị dữ liệu metric này. Bằng cách tạo các dashboard và biểu đồ trong Grafana, bạn có thể theo dõi hiệu suất, tình trạng và xu hướng của hệ thống PostgreSQL, giúp bạn phát hiện sự cố, tối ưu hiệu suất và đưa ra quyết định dựa trên dữ liệu thống kê và phân tích.

2. Tóm tắt quy trình triển khai.
Để giám sát PostgreSQL với Grafana và Prometheus trên Ubuntu 20.04, bạn cần cài đặt và cấu hình các thành phần sau đây:

  • Cài đặt và cấu hình PostgreSQL: Đầu tiên, bạn cần cài đặt PostgreSQL trên máy chủ Ubuntu 20.04 và cấu hình nó để chấp nhận kết nối từ các máy chủ khác.
  • Cài đặt và cấu hình Prometheus: Tiếp theo, bạn cần cài đặt Prometheus trên máy chủ Ubuntu 20.04. Prometheus sẽ thu thập và lưu trữ các metric từ PostgreSQL.
  • Cài đặt và cấu hình PostgreSQL Exporter: PostgreSQL Exporter là một công cụ được sử dụng để xuất các metric của PostgreSQL cho Prometheus. Bạn cần cài đặt PostgreSQL Exporter trên máy chủ Ubuntu 20.04 và cấu hình nó để kết nối và thu thập metric từ PostgreSQL.
  • Cấu hình Prometheus để scrape PostgreSQL Exporter: Bạn cần chỉnh sửa file cấu hình của Prometheus để thêm PostgreSQL Exporter là một target để scrape metric. Điều này cho phép Prometheus lấy dữ liệu metric từ PostgreSQL Exporter.
  • Cài đặt và cấu hình Grafana: Grafana là một công cụ trực quan hóa dữ liệu mạnh mẽ. Bạn cần cài đặt Grafana trên máy chủ Ubuntu 20.04 và cấu hình nó để kết nối với Prometheus làm nguồn dữ liệu.
  • Tạo các Dashboard trong Grafana: Bạn có thể tạo các biểu đồ và dashboard trong Grafana để hiển thị các metric được thu thập từ PostgreSQL qua Prometheus và PostgreSQL Exporter.

Với cấu hình này, bạn có thể theo dõi và trực quan hóa các metric của PostgreSQL sử dụng Grafana trên Ubuntu 20.04. Bạn có thể tạo các biểu đồ, bảng điều khiển và cảnh báo để theo dõi hiệu suất và tình trạng của PostgreSQL.

3. Triển khai.

Bước 1 – Cài đặt PostgresSQL.

Đương nhiên rồi, phải cài đặt PostgresSQL mới có cái mà monitor, xem bài hướng dẫn sau để cài nó https://wiki.hoanghd.com/cai-dat-postgresql-tren-he-dieu-hanh-ubuntu/

Bước 2 – Cài đặt Prometheus.

Thực hiện theo bài https://wiki.hoanghd.com/cach-cai-dat-prometheus-len-he-dieu-hanh-ubuntu/

Bước 3 – Cài đặt Postgres Exporter

Lấy phiên bản mới nhất của Postgres Exporter.

VERSION=$(curl -s https://api.github.com/repos/prometheus-community/postgres_exporter/releases/latest|grep tag_name|cut -d '"' -f 4|sed 's/v//')

Xác nhận lại phiên bản của Postgres Exporter.

$ echo $VERSION
0.12.1

Tạo thư mục chứa Postgres Exporter và di chuyển vào nó.

sudo mkdir /opt/postgres_exporter && cd /opt/postgres_exporter

Tải Postgres Exporter về thư mục này.

sudo wget https://github.com/prometheus-community/postgres_exporter/releases/download/v$VERSION/postgres_exporter-$VERSION.linux-amd64.tar.gz

Giải nén file vừa tải về.

sudo tar -xf postgres_exporter-$VERSION.linux-*.tar.gz

Copy các thành phần của Postgres Exporter sang thư mục /usr/local/bin.

sudo cp postgres_exporter-$VERSION.linux-*/postgres_exporter /usr/local/bin

Tạo file biến môi trường postgres_exporter.env với nội dung dưới. Nội dung này chúng ta tạo một file tin có tên là postgres_exporter.env và thiết lập các biến môi trường cho PostgreSQL Exporter.

  • Dòng đầu tiên là một ví dụ để giám sát tất cả các cơ sở dữ liệu trên PostgreSQL. Biến DATA_SOURCE_NAME được thiết lập để kết nối với PostgreSQL thông qua postgresql://postgres:postgres@localhost:5432/?sslmode=disable. Điều này đặt tên người dùng (postgres) và mật khẩu (postgres) để truy cập vào PostgreSQL trên máy local, và sslmode=disable để vô hiệu hóa SSL.
  • Dòng thứ hai là một ví dụ để giám sát một cơ sở dữ liệu cụ thể trên PostgreSQL. Nếu bạn muốn giám sát một cơ sở dữ liệu cụ thể, bạn có thể uncomment (loại bỏ dấu #) dòng này và chỉnh sửa thông tin kết nối. Bạn cần thay thế username, password, localhost, 5432, và database-name bằng các giá trị tương ứng cho cơ sở dữ liệu bạn muốn giám sát.

Sau khi tạo và cấu hình file tin postgres_exporter.env, bạn có thể sử dụng nó để cung cấp các cấu hình kết nối cho PostgreSQL Exporter.

cat > postgres_exporter.env << 'OEF'
##To monitor all Databases##
DATA_SOURCE_NAME="postgresql://postgres:postgres@localhost:5432/?sslmode=disable"

###To monitor a Specific database, uncomment and edit the line below###
# DATA_SOURCE_NAME="postgresql://username:password@localhost:5432/database-name?sslmode=disable"
OEF

Tạo file service Postgres Exporter.

cat > /etc/systemd/system/postgres_exporter.service << 'OEF'
[Unit]
Description=Prometheus exporter for Postgresql
Wants=network-online.target
After=network-online.target

[Service]
User=postgres_exporter
Group=postgres_exporter
WorkingDirectory=/opt/postgres_exporter
EnvironmentFile=/opt/postgres_exporter/postgres_exporter.env
ExecStart=/usr/local/bin/postgres_exporter --web.listen-address=:9187 --web.telemetry-path=/metrics
Restart=always

[Install]
WantedBy=multi-user.target

[Install]
WantedBy=multi-user.target

[Install]
WantedBy=multi-user.target
OEF

Chạy lệnh sau để tạo một người dùng hệ thống mới có tên “postgres_exporter”, Lệnh này sẽ tạo một người dùng hệ thống (-r) với shell /sbin/nologin và không tạo thư mục home.

sudo useradd -r -s /sbin/nologin postgres_exporter

Ta tạo một file tin có tên là postgres_exporter.service trong thư mục /etc/systemd/system/ để cấu hình PostgreSQL Exporter như một dịch vụ systemd.

  • Phần [Unit] chỉ định thông tin về dịch vụ, bao gồm mô tả (Description), yêu cầu các unit khác (Wants), và xác định thứ tự chạy sau các unit khác (After).
  • Phần [Service] xác định cách dịch vụ được chạy. Người dùng (User) và nhóm (Group) được đặt là postgres_exporter. Thư mục làm việc (WorkingDirectory) là /opt/postgres_exporter. EnvironmentFile chỉ định đường dẫn tới file tin postgres_exporter.env đã được tạo trước đó, để đọc các biến môi trường. ExecStart xác định lệnh để khởi chạy PostgreSQL Exporter, với địa chỉ lắng nghe (--web.listen-address=:9187) và đường dẫn thống kê (--web.telemetry-path=/metrics). Restart được thiết lập là always để tự động khởi động lại dịch vụ nếu nó dừng.
  • Phần [Install] chỉ định các phụ thuộc và mức độ khởi động dịch vụ.

Sau khi tạo và cấu hình file tin postgres_exporter.service, bạn có thể sử dụng các lệnh systemd để quản lý dịch vụ PostgreSQL Exporter, chẳng hạn như systemctl start postgres_exporter để khởi động dịch vụ, systemctl enable postgres_exporter để tự động khởi động cùng với hệ thống, và systemctl status postgres_exporter để kiểm tra trạng thái của dịch vụ.

sudo chown -R postgres_exporter:postgres_exporter /opt/postgres_exporter

Lệnh daemon-reload sẽ cập nhật file /etc/systemd/system/postgres_exporter.service mà chúng ta mới tạo ở bước trên.

sudo systemctl daemon-reload

Bật tính năng tự khởi động theo OS cho dịch vụ này.

sudo systemctl enable --now postgres_exporter

Khởi động nó.

systemctl start postgres_exporter

Kiếm tra trạng thái.

systemctl status postgres_exporter

Nếu thành công bạn sẽ nhân được trạng thái là Active như dưới.

● postgres_exporter.service - Prometheus exporter for Postgresql
   Loaded: loaded (/etc/systemd/system/postgres_exporter.service; enabled; vendor preset: enabled)
   Active: active (running) since Tue 2023-06-20 08:07:10 UTC; 1min 39s ago
 Main PID: 5775 (postgres_export)
    Tasks: 5 (limit: 4915)
   CGroup: /system.slice/postgres_exporter.service
           └─5775 /usr/local/bin/postgres_exporter --web.listen-address=:9187 --web.telemetry-path=/metrics
...

Xác nhận port 9187 của dịch vụ postgres_expor đã listen.

$ netstat -tlnp | grep postgres_expor
tcp6       0      0 :::9187                 :::*                    LISTEN      5775/postgres_expor

Thêm nội dung dưới vào file /etc/prometheus/prometheus.yml. Phần cấu hình này trong Prometheus là để định nghĩa một công việc (job) có tên là “postgres_exporter” để thu thập thông tin từ PostgreSQL Exporter:

  - job_name: "postgres_exporter"
    scrape_interval: 5s
    static_configs:
      - targets: ['192.168.13.208:9187']
  • job_name: Đây là tên của công việc (job), trong trường hợp này là “postgres_exporter”. Nó sẽ được sử dụng để nhận dạng và xác định các cấu hình riêng cho công việc này trong Prometheus.
  • scrape_interval: Đây là khoảng thời gian giữa các lần thu thập thông tin từ exporter. Trong trường hợp này, là 5 giây (5s). Điều này có nghĩa là Prometheus sẽ gửi yêu cầu scrape (lấy thông tin) đến PostgreSQL Exporter mỗi 5 giây.
  • static_configs: Đây là phần cấu hình tĩnh cho công việc (job), cho phép định nghĩa các mục tiêu (targets) mà Prometheus sẽ scrape dữ liệu từ. Trong trường hợp này, mục tiêu là ‘192.168.13.208:9187’, tức là địa chỉ IP và cổng của PostgreSQL Exporter. Điều này cho phép Prometheus kết nối và lấy thông tin từ exporter để lưu trữ và phân tích.

Với cấu hình trên, Prometheus sẽ thực hiện scrape dữ liệu từ PostgreSQL Exporter mỗi 5 giây và lưu trữ nó để sử dụng cho việc giám sát và tạo đồ thị trong Grafana.

Như vậy cấu hình đầy đủ của bạn có thể sẽ giống thế này hoặc có thể khác tuỳ vào hệ thống của bạn đang giám sát.

cat > /etc/prometheus/prometheus.yml << 'OEF'
global:
  scrape_interval: 15s
  evaluation_interval: 15s

alerting:
  alertmanagers:
    - static_configs:
        - targets: []

rule_files:

scrape_configs:
  - job_name: "prometheus"
    static_configs:
      - targets: ["localhost:9090"]

  - job_name: "postgres_exporter"
    scrape_interval: 5s
    static_configs:
      - targets: ['192.168.13.208:9187']
OEF

Khởi động lại dịch vụ Prometheus.

sudo systemctl restart prometheus

Xác nhận Prometheus đã khởi động thành công.

sudo systemctl status prometheus

Đầu ra của trạng thái Prometheus khi nó khởi động thành công.

● prometheus.service - Prometheus
   Loaded: loaded (/etc/systemd/system/prometheus.service; enabled; vendor preset: enabled)
   Active: active (running) since Tue 2023-06-20 08:15:54 UTC; 2s ago
 Main PID: 6397 (prometheus)
    Tasks: 13 (limit: 4915)
   CGroup: /system.slice/prometheus.service
           └─6397 /usr/local/bin/prometheus --config.file=/etc/prometheus/prometheus.yml --storage.tsdb.path=/var/lib/prometheus/ --web.console.templates=/etc/prometheus/consoles --web.console.libraries=/etc/prometheus/console_libraries --web.listen-address=0.0.0.0:9090
...

Giờ đây bạn có thể sử dụng lệnh curl http://192.168.13.208:9187/metrics với 192.168.13.208 là IP của Prometheus và 9187 là port của Postgres Exporter.

  # TYPE go_gc_duration_seconds summary
0  go_gc_duration_seconds{quantile="0"} 3.6192e-05
802go_gc_duration_seconds{quantile="0.25"} 0.000100924
6  go_gc_duration_seconds{quantile="0.5"} 0.000131528
  0go_gc_duration_seconds{quantile="0.75"} 0.00018483
     go_gc_duration_seconds{quantile="1"} 0.001505618
0  go_gc_duration_seconds_sum 0.014875058
 79go_gc_duration_seconds_count 90
78  # HELP go_goroutines Number of goroutines that currently exist.
  # TYPE go_goroutines gauge
  go_goroutines 10
0 # HELP go_info Information about the Go environment.
--# TYPE go_info gauge
:-go_info{version="go1.20.5"} 1
-:-# HELP go_memstats_alloc_bytes Number of bytes allocated and still in use.
-# TYPE go_memstats_alloc_bytes gauge
  go_memstats_alloc_bytes 4.1326e+06
0:0# HELP go_memstats_alloc_bytes_total Total number of bytes allocated, even if freed.
0:# TYPE go_memstats_alloc_bytes_total counter
01go_memstats_alloc_bytes_total 1.64859744e+08
 --:-# HELP go_memstats_buck_hash_sys_bytes Number of bytes used by the profiling bucket hash table.
-:# TYPE go_memstats_buck_hash_sys_bytes gauge
--go_memstats_buck_hash_sys_bytes 4570
  7# HELP go_memstats_frees_total Total number of frees.
97# TYPE go_memstats_frees_total counter
8go_memstats_frees_total 386802
# HELP go_memstats_gc_sys_bytes Number of bytes used for garbage collection system metadata.
# TYPE go_memstats_gc_sys_bytes gauge
go_memstats_gc_sys_bytes 7.941688e+06
# HELP go_memstats_heap_alloc_bytes Number of heap bytes allocated and still in use.
100# TYPE go_memstats_heap_alloc_bytes gauge
  go_memstats_heap_alloc_bytes 4.1326e+06
...

Nếu bạn chuyển qua phần Targets của Prometheus bạn cũng sẽ thấy Targets của postgres_exporter đang ở trạng thái UP.

Bước 4 – Cài đặt Grafana.

Làm theo hướng dẫn https://wiki.hoanghd.com/huong-dan-cai-dat-grafana/

Bước 5 – Thêm Dashboard vào Grafana.

Muốn xem được thông tin metric của MongoDB Exporter thì đầu tiên bạn phải thêm Datasource của Prometheus vào Grafana trước, các bước theo trình tự như dưới.

Bấm Add data source.

Chọn Datasource là Prometheus, đặt tên cho Datasource và điền thông tin url của Prometheus vào Prometheus server URL.

Kéo xuống dưới cùng và bấm Save and test (1), bạn nhận được thông báo (2) tức là đã thành công.

Bước 6 – Thêm Dashboard

Để tạo Dashboards thì bạn vào Dashboards.

Vào Import một Dashboard dành cho MongoDB.

Thông tin để import bạn lấy ở url này https://wiki.hoanghd.com/wp-content/uploads/codes/grafana-dashboard-postgres-exporter.yml

Bạn có thể để tên mặc định hoặc chỉnh sửa tuỳ ý và xong thì bấm Import.

Kết quả nhé.

LEAVE A REPLY

Please enter your comment!
Please enter your name here

4,956FansLike
256FollowersFollow
223SubscribersSubscribe
spot_img

Related Stories