Hướng dẫn sử dụng plugin [inputs.procstat] của TIG stack để giám sát process

30/12/2020

Tiếp tục chuỗi bài viết về TIG stack, hôm nay Onet sẽ hướng dẫn các bạn sử dụng plugin [inputs.procstat] để giám sát hệ thống.

Plugin [inputs.procstat] là một phần có sẵn của Telegraf. Sử dụng plugin này, ta có thể giám sát các tiến trình trên hệ thống một cách dễ dàng. Để sử dụng chúng ta chỉ cần sửa một chút trong file cấu hình telegraf.

Ví dụ ở trong bài này tôi sẽ giám sát một host cài wordpress với IP là 10.10.34.174.

Sửa file /etc/telegraf/telegraf.conf trên hệ thống bạn đang giám sát.

nano /etc/telegraf/telegraf.conf

Tìm đến mục [[inputs.procstat]], uncomment và sửa thành như sau:

[[inputs.procstat]]         exe = "."         pid_tag = true

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

systemctl restart telegraf

Sau đó truy cập vào trang grafana của bạn, thêm một số biến trong dashboard của bạn như sau cho dễ quản lý. Phần này bạn có thể không làm cũng được.

Tiếp theo, tạo một đồ thị, và truy vấn các thông tin mà bạn cần giám sát trên host này.

Ví dụ ở đây tôi muốn truy vấn mức độ sử dụng CPU của các tiến trình trên host này. Tôi thực hiện như sau:

SELECT last("cpu_usage") FROM "procstat" WHERE ("host" = 'wp') AND $timeFilter GROUP BY time($__interval), "pid", "process_name", "user" fill(none)

Nếu bạn không rành cách truy vấn với InfluxDB thì có thể xem hình minh họa dưới đây. Hình dưới đây chọn một host cụ thể là host wp.

Và chỉnh sửa cách hiển thị của đồ thị này như sau:

Hoặc nếu bạn chọn dùng biến thì thực hiện theo hình dưới đây. Lưu ý nếu chọn theo biến sẽ không cấu hình cảnh báo được.

SELECT last("cpu_usage") FROM "procstat" WHERE ("host" =~ /^$host$/) AND $timeFilter GROUP BY time($__interval), "pid", "/^$process$/", "/^$user$/" fill(none)

Tương tự, tôi sẽ tạo thêm một đồ thị thể hiện mức độ sử dụng RAM của các tiến trình trên host này như sau:

SELECT last("cpu_usage") FROM "procstat" WHERE ("host" = 'wp') AND $timeFilter GROUP BY time($__interval), "pid", "/^$process$/", "/^$user$/" fill(none)

Nếu muốn hiển thị theo đơn vị byte thì chọn field memory_rss thay cho memory_usage

Bây giờ tôi sẽ thử đẩy lượng truy cập lên trang wordpress này với công cụ siege.

siege 10.10.34.174

Hướng dẫn sử dụng siege

Lưu ý: Bạn hãy sử dụng công cụ này với mục đích hợp pháp.

Kết quả:

Có thể thấy xuất hiện rất nhiều tiến trình httpd do công cụ siege sinh ra, tiến trình mysqld cũng sử dụng CPU nhiều vì mysql đang phải truy vấn liên tục cho dịch vụ web.

2 core CPU đã bị sử dụng hết (từ 2% lên 100%)

Các tiến trình httpd và mysqld sử dụng RAM không nhiều lắm

RAM sử dụng tăng từ 26% lên 33%

Sử dụng biến

Nếu bạn đã thêm biến như phần trên tôi đã hướng dẫn thì bạn có thể sử dụng các biến để theo dõi các tiến trình cụ thể, bởi các user cụ thể.

Đầu tiên, hãy chắc chắn rằng bạn đã chọ các biến sau trong query

Sau đó bạn có thể chọn hiển thị theo biến tùy ý.

Ví dụ: Tôi chỉ muốn theo dõi các tiến trình httpd và mysqld. Bỏ qua tất cả các tiến trình khác. Tôi sẽ chọn biến như sau:

  • Tôi muốn theo dõi trên host wordpress có tên wp
  • Databases tôi sử dụng là InfluxDB
  • Mỗi 1 giây sẽ làm mới kết quả một lần
  • Tôi theo dõi tiến trình httpd và mysqld bới user apache và mysql

Kết quả:

Bạn có thể thấy bây giờ đồ thị của tôi chỉ hiển thị các tiến trình httpd và mysqld

Kết luận

Như vậy chúng tôi đã hướng dẫn cơ bản cho bạn cách sử dụng plugin [inputs.procstat] để bạn giám sát hệ thống với TIG stack.

Chúc các bạn thành công!!

Xem thêm hướng dẫn cài đặt TIG stack tại đây: https://onet.com.vn/huong-dan-cai-dat-tig-stack-telegraf-influxdb-grafana/

ONET IDC thành lập vào năm 2012, là công ty chuyên nghiệp tại Việt Nam trong lĩnh vực cung cấp dịch vụ Hosting, VPS, máy chủ vật lý, dịch vụ Firewall Anti DDoS, SSL… Với 10 năm xây dựng và phát triển, ứng dụng nhiều công nghệ hiện đại, ONET IDC đã giúp hàng ngàn khách hàng tin tưởng lựa chọn, mang lại sự ổn định tuyệt đối cho website của khách hàng để thúc đẩy việc kinh doanh đạt được hiệu quả và thành công.
Bài viết liên quan

How to Use Network Manager on OpenSUSE

The NetworkManager app is the ideal solution for managing networks. It’s especially useful if you’re running openSUSE...
29/12/2020

Installing Apache Spark on Ubuntu 17.10

Apache Spark is a data analytics tool that can be used to process data from HDFS, S3 or other data sources in memory. In...
28/12/2020

[MongoDB] Hướng dẫn cài đặt MongoDB trên CentOS 7

MongoDB là 1 cơ sở dữ liệu đa nền tảng, được sử dụng để lưu trữ dữ liệu khối lượng lớn....
30/12/2020
Bài Viết

Bài Viết Mới Cập Nhật

Mua Proxy V6 Nuôi Facebook Spam Hiệu Quả Tại Onetcomvn
03/06/2024

Hướng dẫn cách sử dụng ProxyDroid để duyệt web ẩn danh
03/06/2024

Mua proxy Onet uy tín tại Onet.com.vn
03/06/2024

Thuê mua IPv4 giá rẻ, tốc độ nhanh, uy tín #1
28/05/2024

Thuê địa chỉ IPv4 IPv6 trọn gói ở đâu chất lượng, giá RẺ nhất?
27/05/2024