Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 29 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
29
Dung lượng
147,03 KB
Nội dung
Hướng dẫn cài đặt Rsyslog 5.7.x trên nền tảng CentOS 5.x QuanTriMang - Trong bài hướng dẫn sau, chúng tôi sẽ trình bày một số bước cơ bản để cài đặt và cấu hình syslog server bằng cách sử dụng Rsyslog. Theo thông tin từ phía hãng, Rsyslog có khả năng cải thiện khả năng hỗ trợ syslogd, có thể được sử dụng như 1 phương án thay thế hoặc dự phòng. Bên c ạnh đó, những tính năng nâng cao khá phù h ợp với các tầng lớp doanh nghiệp, khả năng bảo mật mã hóa cũng khá đơn giản và dễ thiết lập, dù cho đối tượng người sử dụng có ít kinh nghiệm. Cụ thể, chúng ta sẽ cùng nhau kết hợp và cài đặt tất cả các tính năng của Rsyslog 5.7.2 trên nền tảng CentOS 5.5 server. Để bắt đầu, chúng ta cần cài đặt những gói hỗ trợ sau: yum install -y pcre pcre-devel mysql-server mysql-devel gnutls gnutls-devel gnutls- utils net-snmp net-snmp-devel net-snmp-libs net- snmp-perl net-snmp-utils libnet libnet- devel Tiếp theo là gói librelp (Reliable Event Logging Protocol Library) để sử dụng các thư viện dành cho giao thức RELP – có nhiệm vụ cung cấp khả năng ghi lại các sự kiện xảy ra trong hệ thống mạng và đảm bảo rằng không bỏ sót bất kỳ tin nhắn cũng như email nào, cho dù có vấn đề xảy ra với quá trình kết nối hoặc các đầu peer không ổn định. cd /tmp wget http://download.rsyslog.com/librelp/librelp- 1.0.0.tar.gz tar -xvf librelp-1.0.0.tar.gz cd librelp-1.0.0 ./configure prefix=/usr make make install cd /tmp wget http://sourceforge.net/projects/libestr/file s/libestr-0.1.0.tar.gz/download tar -xvf libestr-0.1.0.tar.gz cd libestr-0.1.0 ./configure prefix=/usr make make install cd /tmp wget http://www.libee.org/files/download/libee- 0.1.0.tar.gz tar -xvf libee-0.1.0.tar.gz cd libee-0.1.0 ./configure prefix=/usr make make install Tại thời điểm bài viết này, chúng tôi sử dụng rsyslog 5.7.2: cd /tmp wget http://www.rsyslog.com/files/download/rsyslo g/rsyslog-5.7.2.tar.gz tar -xvf rsyslog-5.7.2.tar.gz cd rsyslog-5.7.2 Để tìm hiểu thông tin về những tùy chọn có sẵn trong Rsyslog, các bạn có thể sử dụng lệnh ./configure –help. Câu lệnh sau sẽ kích hoạt hầu hết các tính năng rsyslog như Compression, Multithreading, MySql, SNMP, Mail, RELP : ./configure enable-regexp enable-zlib enable-pthreads enable-klog enable-inet enable-unlimited-select enable-debug enable-rtinst enable-memcheck enable- diagtools enable-mysql enable-snmp enable-gnutls enable-rsyslogrt enable- rsyslogd enable-extended-tests enable- mail enable-imptcp enable-omruleset enable-valgrind enable-imdiag enable- relp enable-testbench enable-imfile enable-omstdout enable-omdbalerting enable-omuxsock enable-imtemplate enable-omtemplate enable-pmlastmsg enable-omudpspoof enable-omprog enable- impstats make make install Cài đặt và khởi tạo cơ sở dữ liệu MySQL: mysql -u root -p < plugins/ommysql/createDB.sql mysql -u root -p mysql GRANT ALL ON Syslog.* TO rsyslog@localhost IDENTIFIED BY 'your-mysql-password'; flush privileges; Tiếp theo, chúng ta sẽ cấu hình mã init: vi /etc/init.d/rsyslog #!/bin/bash # # rsyslog Starts rsyslogd/rklogd. # # # chkconfig: - 12 88 # description: Syslog is the facility by which many daemons use to log \ # messages to various system log files. It is a good idea to always \ # run rsyslog. ### BEGIN INIT INFO # Provides: $syslog # Required-Start: $local_fs $network $remote_fs # Required-Stop: $local_fs $network $remote_fs # Default-Stop: 0 1 2 3 4 5 6 # Short- Description: Enhanced system logging and kernel message trapping daemons # Description: Rsyslog is an enhanced multi- threaded syslogd supporting, # among others, MySQL, syslog/tcp, RFC 3195, permitted # sender lists, filtering on any message part, and fine # grain output format control. ### END INIT INFO # Source function library. . /etc/init.d/functions RETVAL=0 start() { [ -x /usr/local/sbin/rsyslogd ] || exit 5 #[ -x /usr/local/sbin/rklogd ] || exit 5 # Do not start rsyslog when sysklogd is running if [ -e /var/run/syslogd.pid ] ; then echo $"Shut down sysklogd before you run rsyslog"; exit 1; fi # Source config if [ -f /etc/sysconfig/rsyslog ] ; then . /etc/sysconfig/rsyslog else #SYSLOGD_OPTIONS="-c3" SYSLOGD_OPTIONS="-c5" #KLOGD_OPTIONS="-2" fi if [ -z "$SYSLOG_UMASK" ] ; then SYSLOG_UMASK=077; fi umask $SYSLOG_UMASK echo -n $"Starting system logger: " daemon /usr/local/sbin/rsyslogd $SYSLOGD_OPTIONS RETVAL=$? echo #echo -n $"Starting kernel logger: " #daemon rklogd $KLOGD_OPTIONS #echo [ $RETVAL -eq 0 ] && touch /var/lock/subsys/rsyslog return $RETVAL } stop() { #echo -n $"Shutting down kernel logger: " #killproc rklogd #echo echo -n $"Shutting down system logger: " killproc rsyslogd RETVAL=$? echo [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/rsyslog return $RETVAL } reload() { RETVAL=1 syslog=`cat /var/run/rsyslogd.pid 2>/dev/null` echo -n "Reloading system logger " if [ -n "${syslog}" ] && [ -e /proc/"${syslog}" ]; then kill -HUP "$syslog"; RETVAL=$? fi if [ $RETVAL -ne 0 ]; then [...]... lập Sau đây, chúng ta sẽ thiết lập Syslog và Rsyslog: service syslog stop chkconfig syslog off chmod 755 /etc/init.d /rsyslog chkconfig add rsyslog chkconfig rsyslog on Các đoạn mã init có thể download tại đây (http://honeynet.ir/software /rsyslog/ ) Một số mẫu tham khảo khác các bạn có thể tìm và tham khảo thêm tại trang chủ (http://www .rsyslog. com/): vi /etc /rsyslog. conf # Input Modules ... comment $IncludeConfig /etc /rsyslog. d/*.conf # -This line is comment #if message contains 'network error' then run the restart-network.sh shell script!!! #:msg, contains, "network error" ^/root/restart-network.sh Sau đó, khởi động Rsyslog: chmod 640 /etc /rsyslog. conf service rsyslog start tail -f /var/log/messages Và kiểm tra quá trình hoạt động của Rsyslog như sau: logger "this... -This line is comment $ModLoad ommail.so # Send mail #$ActionMailSMTPServer mail.example.net #$ActionMailFrom rsyslog@ example.net #$ActionMailTo operator@example.net #$ActionMailTo admin@example.net #$template mailSubject,"disk problem on %hostname%" #$template mailBody, "RSYSLOG Alert\r\nmsg='%msg%'" #$ActionMailSubject mailSubject #$ActionExecOnlyOnceEveryInterval 21600 #if $msg contains... 0640 $RepeatedMsgReduction on $WorkDirectory /var/log /rsyslog # default location for work (spool) files $ActionQueueType LinkedList # use asynchronous processing $ActionQueueFileName queue # set file name, also enables disk mode $ActionResumeRetryCount -1 # infinite retries on insert failure $ActionQueueSaveOnShutdown on # save in-memory data if rsyslog shuts down $MainMsgQueueMaxFileSize 100M $ActionQueueMaxFileSize... #fi #if [ $RETVAL -ne 0 ]; then #failure #else #success #fi #echo return $RETVAL } rhstatus() { status rsyslogd #status rklogd } restart() { stop start } case "$1" in start) start ;; stop) stop ;; restart) restart ;; reload|force-reload) reload ;; status) rhstatus ;; condrestart) [ -f /var/lock/subsys /rsyslog ] && restart || : ;; *) echo $"Usage: $0 {start|stop|restart|reload|force- reload|condrestart}"... %syslogtag%%msg:::sp-if-no1st-sp%%msg:::drop-last-lf%\n" $template ForwardFormat,"%TIMESTAMP:::date -rfc3339% %HOSTNAME% %syslogtag:1:32%%msg:::sp-if-no-1stsp%%msg%" # Selector lines are somewhat different from stock syslogd With # rsyslog, you can add a semicolon ";" after the target and then # the template name That will assign this template to the respective # action If no template name is given, a hardcoded template is used #... *.example.net, somehost.example.com #*.* @(z9)192.168.x.x:514 # Forward via RELP Protocol : #*.* :omrelp:192.168.2.4:20514;TraditionalFo rmat # Store all log files in MySQL DB : #*.* :ommysql:127.0.0.1,Syslog ,rsyslog, yourmysql-password # -This line is comment # -This line is comment # Log all kernel messages to the console # Logging much else clutters up the screen... (http://www .rsyslog. com/): vi /etc /rsyslog. conf # Input Modules This line is comment # -This line is comment $ModLoad impstats.so $PStatsInterval 300 syslog.info /var/log /rsyslog- stats # -This line is comment $ModLoad immark.so # provides MARK message capability $ModLoad imuxsock.so # provides support for local system logging (via logger command) . Hướng dẫn cài đặt Rsyslog 5. 7. x trên nền tảng CentOS 5. x QuanTriMang - Trong bài hướng dẫn sau, chúng tôi sẽ trình bày một số bước cơ bản để cài đặt và cấu hình syslog. Cụ thể, chúng ta sẽ cùng nhau kết hợp và cài đặt tất cả các tính năng của Rsyslog 5. 7. 2 trên nền tảng CentOS 5. 5 server. Để bắt đầu, chúng ta cần cài đặt những gói hỗ trợ sau: yum install -y. prefix=/usr make make install Tại thời điểm bài viết này, chúng tôi sử dụng rsyslog 5. 7. 2: cd /tmp wget http://www .rsyslog. com/files/download/rsyslo g /rsyslog- 5. 7. 2.tar.gz tar -xvf rsyslog- 5. 7. 2.tar.gz