Hướng dẫn cài đặt rsyslog trên ubuntu
Logrotate là một tiện ích hệ thống quản lý việc tự động xoay và nén các tệp nhật ký (log files). Nếu các tệp nhật ký không được xoay, nén và cắt bỏ định kỳ, cuối cùng chúng có thể chiếm hết dung lượng đĩa có sẵn trên hệ thống. Show Logrotate được cài đặt mặc định trên Ubuntu 20.04 và được thiết lập để xử lý nhu cầu xoay vòng nhật ký của tất cả các gói đã cài đặt, bao gồm
9, bộ xử lý nhật ký hệ thống mặc định. Trong bài viết này, chúng ta sẽ khám phá cấu hình Logrotate mặc định, sau đó thiết lập cấu hình xoay vòng nhật ký cho một ứng dụng tùy chỉnh hư cấu. Hướng dẫn này giả sử bạn có máy chủ Ubuntu 20.04, với non-root sudo-enabled user (không hỗ trợ sudo), như được mô tả trong Thiết lập máy chủ ban đầu với Ubuntu 20.04. Logrotate cũng có sẵn trên nhiều bản phân phối Linux khác, nhưng cấu hình mặc định có thể khác. Các phần khác của hướng dẫn này vẫn sẽ áp dụng, miễn là phiên bản Logrotate của bạn tương tự như Ubuntu 20.04. Làm theo Bước 1 để xác định phiên bản Logrotate của bạn. Đăng nhập vào máy chủ của bạn với tư cách là sudo-enabled user của bạn để bắt đầu. Logrotate được cài đặt theo mặc định trên Ubuntu. Tuy nhiên, nếu bạn cần cài đặt nó, hãy chạy các lệnh sau để cập nhật danh sách gói của bạn và truy xuất gói:
Nếu bạn đang sử dụng máy chủ không phải Ubuntu, trước tiên hãy đảm bảo rằng Logrotate đã được cài đặt bằng cách yêu cầu thông tin phiên bản của nó:
Nếu Logrotate được cài đặt nhưng số phiên bản khác nhau đáng kể, bạn có thể gặp sự cố với một số tùy chọn cấu hình được khám phá trong hướng dẫn này. Tham khảo tài liệu dành cho phiên bản Logrotate cụ thể của bạn bằng cách đọc trang hướng dẫn sử dụng (
Bạn cũng có thể tham khảo phiên bản trực tuyến của tài liệu Logrotate. Tiếp theo, chúng ta sẽ xem xét cấu trúc cấu hình mặc định của Logrotate trên Ubuntu. Thông tin cấu hình của Logrotate thường có thể được tìm thấy ở hai nơi trên Ubuntu:
Theo mặc định,
8 sẽ thiết lập cấu hình luân phiên nhật ký hàng tuần, với các tệp nhật ký thuộc sở hữu của root user và syslog group, với bốn tệp nhật ký được giữ lại cùng một lúc (
0). Hãy xem tệp cấu hình Logrotate của gói trong
3.
2 tệp cho tiện ích gói
5:
Tệp này chứa các khối cấu hình cho hai tệp nhật ký khác nhau trong thư mục
4:
5 và
6. Cả hai đều có các tùy chọn giống nhau. Bất kỳ tùy chọn nào không được đặt trong các khối cấu hình này sẽ kế thừa các giá trị mặc định hoặc các giá trị được đặt trong
1. Mọi cài đặt trong tệp logrotate sẽ ghi đè các giá trị mặc định của logrotate, được thiết lập cấu hình trong
1. Các tùy chọn được đặt cho nhật ký
5 là:
Các tệp cấu hình này cũng kế thừa hành vi
0 mặc định, hướng dẫn Logrotate tạo nhật ký mới sau khi xoay. Điều này có thể được ghi đè với
0, mặc dù điều đó sẽ vô hiệu hóa hiệu quả hầu hết các chức năng khác. Có nhiều tùy chọn cấu hình hơn có sẵn. Bạn có thể đọc về tất cả chúng bằng cách gõ
1 trên dòng lệnh để hiển thị trang hướng dẫn sử dụng Logrotate. Tiếp theo, chúng ta sẽ thiết lập một tệp cấu hình để xử lý nhật ký cho một dịch vụ hư cấu có tên là
2. Để quản lý các tệp nhật ký bằng logrotate cho các ứng dụng bên ngoài các dịch vụ hệ thống được đóng gói sẵn và cấu hình sẵn, chúng ta có hai tùy chọn:
Hãy xem xét hai tùy chọn này với một số thiết lập mẫu. Chúng ta muốn thiết lập cấu hình xoay vòng nhật ký cho một máy chủ web hư cấu đặt
7 và
8 vào
9. Nó chạy với tư cách là
0 user và group. Để thêm cấu hình cho các tệp nhật ký ứng dụng của bạn vào
4, trước tiên hãy mở một tệp mới trong thư mục
3 bằng
3 hoặc trình soạn thảo ưa thích của bạn:
Thêm các dòng sau vào tệp cấu hình mới của bạn: /etc/logrotate.d/your-app
Một số chỉ thị cấu hình mới trong tệp này là:
Để lưu và thoát
3, hãy nhấn
9, và khi được nhắc, hãy nhấn
0 rồi nhấn
1. Bạn có thể kiểm tra tệp cấu hình bằng cách chạy thử:
Lệnh này gọi
2, trỏ nó đến tệp cấu hình tiêu chuẩn và bật chế độ gỡ lỗi. Thông tin sẽ in ra các tệp nhật ký mà Logrotate đang xử lý và nó sẽ làm gì với chúng. Nếu tất cả đều ổn, bạn đã hoàn tất. Công việc Logrotate tiêu chuẩn sẽ chạy mỗi ngày một lần và bao gồm cấu hình mới của bạn. Tiếp theo, chúng ta sẽ thử một thiết lập hoàn toàn không sử dụng cấu hình mặc định của Ubuntu. Trong ví dụ này, chúng ta có một ứng dụng đang chạy dưới dạng user
3, tạo nhật ký được lưu trữ trong
4. Chúng ta muốn xoay các nhật ký này hàng giờ, vì vậy chúng ta cần thiết lập điều này bên ngoài cấu trúc
3 được cung cấp bởi Ubuntu. Trước tiên, chúng ta sẽ tạo một tệp cấu hình trong thư mục chính của chúng ta. Mở nó trong một trình soạn thảo văn bản:
Sau đó, dán vào cấu hình sau: /home/sammy/logrotate.conf
0 Lưu và đóng tập tin. Chúng ta đã gặp tất cả các tùy chọn này trong các bước trước, nhưng hãy tóm tắt: cấu hình này sẽ xoay các tệp hàng giờ, nén và giữ hai mươi bốn nhật ký cũ và tạo một tệp nhật ký mới để thay thế tệp đã xoay. Bạn sẽ cần tùy chỉnh cấu hình cho phù hợp với ứng dụng của mình, nhưng đây là một khởi đầu tốt. Để kiểm tra xem cấu hình có hoạt động hay không, hãy tạo một tệp nhật ký. Đầu tiên
6 vào thư mục chính của user của bạn bằng lệnh
7. Sau đó, tạo một thư mục cho các bản ghi bằng lệnh
8. Cuối cùng tạo một tệp trống trong thư mục
9 bằng lệnh
0. Chạy các lệnh sau để hoàn thành các bước sau:
1 Bây giờ chúng ta có một tệp nhật ký trống ở đúng vị trí, hãy chạy lệnh
2. Vì nhật ký thuộc sở hữu của
3 nên chúng ta không cần sử dụng
3. Tuy nhiên, chúng ta cần chỉ định một tệp trạng thái. Tệp này ghi lại những gì
2 đã tìm thấy và bất kỳ hành động nào mà nó đã thực hiện vào lần cuối cùng nó chạy, để nó biết phải làm gì trong lần chạy tiếp theo. Theo dõi trạng thái này được xử lý cho chúng ta khi sử dụng cấu hình
1 mặc định. Tệp trạng thái được lưu trữ trong
6. Vì chúng ta không sử dụng cấu hình mặc định, chúng ta sẽ cần định cấu hình vị trí tệp trạng thái theo cách thủ công. Chúng ta sẽ yêu cầu Logrotate đặt tệp trạng thái ngay trong thư mục chính của chúng ta cho ví dụ này. Nó có thể đến bất cứ nơi nào có thể tiếp cận và thuận tiện. Chạy lệnh sau để sử dụng
7 mà bạn đã tạo và ghi lại trạng thái mà logrotate gặp phải:
2
3 Cờ
8 sẽ in ra thông tin chi tiết về những gì Logrotate đang làm. Trong trường hợp này, nó không xoay bất cứ thứ gì. Đây là lần đầu tiên Logrotate gặp phải tệp nhật ký này và nó đã có từ 0 giờ nên không nên xoay. Nếu chúng ta kiểm tra tệp trạng thái bằng tiện ích
2, chúng ta sẽ lưu ý rằng Logrotate đã ghi lại một số thông tin về quá trình chạy:
4
5 Logrotate ghi nhận các bản ghi mà nó đã nhìn thấy và thời điểm nó xem xét chúng để quay vòng lần cuối. Nếu chúng ta chạy cùng lệnh này một giờ sau đó, nhật ký sẽ được xoay như mong đợi. Nếu bạn muốn buộc Logrotate xoay tệp nhật ký khi nó không có, hãy sử dụng cờ
00:
6 Điều này rất hữu ích khi kiểm tra
3 và các tập lệnh khác. Cuối cùng, chúng ta cần thiết lập một công việc cron để chạy Logrotate mỗi giờ. Mở crontab của user của bạn:
7 Thao tác này sẽ mở một tệp văn bản. Nếu đây là lần đầu tiên bạn sử dụng cron, bạn có thể được nhắc chọn một trình soạn thảo văn bản mặc định. Nếu bạn không có sở thích, chúng tôi khuyên bạn nên sử dụng
3 cho người dùng mới. Có thể có một số nhận xét đã có trong tệp giải thích cú pháp cron. Di chuyển con trỏ xuống một dòng trống mới ở cuối tệp và thêm phần sau:
8 Nhiệm vụ này sẽ chạy vào phút thứ 14 hàng giờ, hàng ngày. Nó chạy gần giống lệnh
2 mà chúng ta đã chạy trước đó, mặc dù chúng ta đã mở rộng
2 thành đường dẫn đầy đủ của nó là
05 để an toàn. Bạn nên sử dụng các đường dẫn đầy đủ khi viết cron jobs. Để tìm hiểu thêm về cron, bạn có thể xem lại các hướng dẫn khác của chúng tôi. Lưu file và thoát. Thao tác này sẽ cài đặt crontab và tác vụ của chúng ta sẽ chạy theo lịch trình đã chỉ định. Nếu chúng ta truy cập lại thư mục nhật ký của mình trong khoảng một giờ, chúng ta sẽ tìm thấy tệp nhật ký đã xoay và nén
06 (hoặc
07 nếu bạn chạy Logrotate với cờ
00). Trong hướng dẫn này, chúng ta đã xác minh phiên bản Logrotate của mình, khám phá cấu hình Ubuntu Logrotate mặc định và thiết lập hai loại cấu hình tùy chỉnh khác nhau. Để tìm hiểu thêm về dòng lệnh và các tùy chọn cấu hình có sẵn cho Logrotate, bạn có thể đọc trang hướng dẫn sử dụng của nó bằng cách chạy
1 trong thiết bị đầu cuối của bạn hoặc bằng cách truy cập tài liệu trực tuyến. |