intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Hướng dẫn cài đặt Rsyslog 5.7.x trên nền tảng CentOS 5.x

Chia sẻ: Cong Thanh | Ngày: | Loại File: PDF | Số trang:29

109
lượt xem
8
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

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ễ...

Chủ đề:
Lưu

Nội dung Text: Hướng dẫn cài đặt Rsyslog 5.7.x trên nền tảng CentOS 5.x

  1. 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
  2. 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
  3. 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
  4. 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 --
  5. 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. #
  6. # # 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,
  7. # 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
  8. 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: "
  9. 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: "
  10. 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
  11. failure else success fi echo RETVAL=1 #echo -n "Reloading kernel logger..." #klog=`cat /var/run/rklogd.pid 2>/dev/null` #if [ -n "${klog}" ] && [ -e /proc/"${klog}" ]; then #kill -USR2 "$klog"; # RETVAL=$? #fi #if [ $RETVAL -ne 0 ]; then #failure #else #success
  12. #fi #echo return $RETVAL } rhstatus() { status rsyslogd #status rklogd } restart() { stop start } case "$1" in start) start ;; stop)
  13. stop ;; restart) restart ;; reload|force-reload) reload ;; status) rhstatus ;; condrestart) [ -f /var/lock/subsys/rsyslog ] && restart || : ;; *) echo $"Usage: $0 {start|stop|restart|reload|force-
  14. reload|condrestart}" exit 2 esac exit $? Hãy lưu ý đến giá trị SYSLOGD_OPTIONS="-c5" đã được thiết 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
  15. # 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) $ModLoad imklog.so # provides kernel logging support (previously done by rklogd) #-------------------------------------- ------------This line is comment
  16. $ModLoad imudp.so # provides UDP syslog reception $UDPServerAddress * # all local interfaces $UDPServerRun 514 # start UDP server (log server receiver) #-------------------------------------- ------------This line is comment $ModLoad imtcp.so # provides TCP syslog reception and GSS-API (if compiled) $InputTCPServerRun 514 # start TCP server (log server receiver) #-------------------------------------- ------------This line is comment $ModLoad imrelp.so # RELP input $InputRELPServerRun 20514 # start RELP Protocol
  17. #-------------------------------------- ------------This line is comment $ModLoad imfile.so # Text file input $InputFileName /var/log/i-am-a-text- file.log $InputFileTag my-text-file: $InputFileStateFile stat-file1 $InputFileSeverity error $InputFileFacility local7 $InputFilePollInterval 10 # check for new lines every 10 seconds $InputRunFileMonitor #-------------------------------------- ------------This line is comment #$ModLoad imgssapi.so # Plain TCP and GSSAPI #$ModLoad im1395.so # Messages via RFC1395
  18. # Output Modules ---------------------- ------------This line is comment #-------------------------------------- ------------This line is comment $ModLoad omsnmp.so # Send SNMP traps #$actionsnmptransport udp #$actionsnmptarget 192.168.x.x #$actionsnmptargetport 162 #$actionsnmpversion 1 #$actionsnmpcommunity public #*.* :omsnmp: #-------------------------------------- ------------This line is comment $ModLoad ommysql.so # Log to MySQL #$ModLoad ompgsql.so # Log to PostgreSQL #-------------------------------------- ------------This line is comment
  19. $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 'hard disk fatal failure' then :ommail:;mailBody #-------------------------------------- ------------This line is comment $ModLoad omrelp.so # Send to another host via RELP #$ModLoad omlibdbi.so # Log via generic DB output
  20. #$ModLoad omgss.so # GSS enabled output # Globals ----------------------------- ------------This line is comment $umask 0000 $DirCreateMode 0640 $FileCreateMode 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
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2