data:image/s3,"s3://crabby-images/92252/92252d21336386be158faefaed50173e6214e503" alt=""
Lookup tables là một công cụ trên Graylog cho phép tra cứu/ánh xạ/sửa đổi giá trị trường message thành giá trị mới và ghi chúng vào một trường mới hoặc ghi đè lên trường cũ. Trong hướng dẫn này tôi sẽ sử dụng nó đề map những user ssh với tên đầy đủ của người dùng tương ứng.
Chuẩn bị
Graylog cần thu thập log ssh từ các client gửi về.
Sử dụng các công cụ để lấy được user ssh đến từ một bản tin SSH.
Cấu hình
Tách user từ bản tin ssh
Có nhiều cách để tách được user từ bản tin SSH thành một trường mới. Ở đây tôi dùng grok pattern.
Xác định bản tin log có chứa user
data:image/s3,"s3://crabby-images/e22fa/e22faf311b9c19ce9a1ce66277ef5dc6ae1c63db" alt=""
Chọn grok pattern
data:image/s3,"s3://crabby-images/1732c/1732c0d1f5528f59d57f961b9d0df41d523e802a" alt=""
Tách message thành các trường
Bạn có thể sử dụng pattern phù hợp hoặc sử dụng như của tôi cho pattern ở khung dưới đây.
%{WORD} %{INT} %{TIME} %{WORD:servername} %{WORD:app_name}\[%{INT}\]\: %{WORD: action_ssh} password for %{WORD:user_ssh} from %{IPV4:ip_ssh}
data:image/s3,"s3://crabby-images/de4b5/de4b576ef47800bbd271595afbf01f2814dac218" alt=""
Click Try against example
để xem thử kết quả
data:image/s3,"s3://crabby-images/be9ea/be9ea0aad6dfe8f02baf78853dc923b472522d5b" alt=""
User ssh đã được tách thành trường user_ssh
Ta thấy đã có trường user ssh
trong bản tin log ssh
data:image/s3,"s3://crabby-images/15484/154849a8f329a471a36a4d32e7f5a784ee17bf6f" alt=""
Tạo lookup tables
data:image/s3,"s3://crabby-images/62352/623527f07ad8a0d0654895ec95b5abaad2359f1b" alt=""
Tạo data adapter
Data adapter được sử dụng để thực hiện tra cứu kết qủa cho một giá trị. Nó có thể đọc từ file CSV, kết nối với cơ sở dữ liệu hoặc thực hiện các request HTTP để nhận kết quả tra cứu.
Click Data Adapter
-> Create data adapter
data:image/s3,"s3://crabby-images/4098b/4098b7e631685d1a083b9c278ad543d35311ede4" alt=""
Chọn CSV File
cho Data Adapter Type
data:image/s3,"s3://crabby-images/74fe6/74fe67f7058f04bbc6c5cc25cc1cab75d9540070" alt=""
Điền các thông tin
data:image/s3,"s3://crabby-images/4aeb3/4aeb3cad070effb576610a0704b6e73ad2e934f6" alt=""
Click Create Adapter
data:image/s3,"s3://crabby-images/f52fa/f52faef8852f100670591e1b262a0cbb8c0f7552" alt=""
Ta thấy có lỗi vì ta chưa tạo file CSV. Ta sẽ tạo file này ở bước sau
Tạo caches
data:image/s3,"s3://crabby-images/e9c37/e9c37aea3ef49f697625157ded8ab314383ff535" alt=""
Chọn Cache Type
data:image/s3,"s3://crabby-images/3694a/3694a97afb471d885622942f3854e6562e8d72d2" alt=""
Config cache
data:image/s3,"s3://crabby-images/5d835/5d8350ab33300d68ca35af2a42dbbd2dbf4d356a" alt=""
data:image/s3,"s3://crabby-images/72a4b/72a4bdf202ef2561c22e727eb8ac1c64ebbcd01b" alt=""
Tạo lookup tables
data:image/s3,"s3://crabby-images/321c4/321c454e9da610e8c29e6b45a9fedd949bf9c867" alt=""
Khai báo thông tin. Data Adapter
và Cache
chọn giá trị vừa tạo ở bước trước.
data:image/s3,"s3://crabby-images/44e35/44e3573d72fa052c72bca4f899fb45a352c5f7d1" alt=""
data:image/s3,"s3://crabby-images/37900/3790027f047e6e07fa326caf87bd32db74ebf8de" alt=""
Ta thấy vẫn có lỗi vì vẫn bị thiếu file CSV. Bây giờ chúng ta sẽ tiến hành tạo file này.
Tạo file CSV
Truy cập vào Graylog server để tạo file CSV
vi /etc/graylog/lookup-table.csv
Thêm nội dung thích hợp. File ví dụ của tôi có nội dung như sau
[root@graylog ~]# cat /etc/graylog/lookup-table.csv
"user_ssh","full_name"
"root","Quan tri vien"
"anv","Nguyen Van A"
"bnv","Nguyen Van B"
Dòng đầu tiên khai báo Key
và Value
như khai báo Adapter
Tạo extractor
Quay trở lại bản tin SSH để tạo extractor
data:image/s3,"s3://crabby-images/43676/4367647359c32144ba205273d72cc2c6b46a893f" alt=""
data:image/s3,"s3://crabby-images/be32a/be32abfb661a6911e1dd437889a7debddc6a5b3c" alt=""
Cấu hình extractor
data:image/s3,"s3://crabby-images/20e51/20e51bb5caa343946bb87051e44d3c05b6678b3d" alt=""
Trong đó:
Lookup Table
là lookup table ta tạo ở trênStore as field
là tên của trường ta muốn lưu giá trị mới
Ta thấy extractor vừa tạo
data:image/s3,"s3://crabby-images/cabb8/cabb8889bb117dca1c873f8e2cdc774f5d9c6ff5" alt=""
Kiểm tra bản tin SSH ta đã thấy có trường full_name_login_ssh
data:image/s3,"s3://crabby-images/d8151/d8151a917cc8034a7828b05d4f0e17e4b98f9e6d" alt=""
Leave a Reply