graylog2+syslog-ng+mongodb構建集中管理日誌服務器

graylog2 是一個開源的日誌存儲系統,是由java語言編寫的server,可以接收TCP,UDP,AMQP的協議發送的日誌信息,而且基於mongodb數據庫服務器快速存儲,可以經過一個基於ruby編寫的web管理界面,讓輕鬆管理你的日誌。下面將在一臺默認安裝的rhel5.x的系統上來實現graylog2+syslog-ng+mongodb構建集中管理日誌服務器html

一.源碼包下載java

  
  
  
  
  1. cd /usr/src 
  2. #mongodb數據庫,在此的主要做用是存儲日誌信息
  3. wget http://fastdl.mongodb.org/linux/mongodb-linux-i686-2.2.1.tgz 
  4. #graylog2日誌服務器 
  5. wget http://cloud.github.com/downloads/Graylog2/graylog2-server/graylog2-server-0.9.5.tar.gz 
  6. #yaml是一種編程語言,
  7. wget http://pyyaml.org/download/libyaml/yaml-0.1.4.tar.gz 
  8. #ruby腳步語言
  9. wget ftp://ftp.ruby-lang.org//pub/ruby/1.9/ruby-1.9.2-p0.tar.gz 
  10. #graylog2-web界面
  11. wget http://cloud.github.com/downloads/Graylog2/graylog2-web-interface/graylog2-web-interface-0.9.5p2.tar.gz 
  12. #eventlog,安裝syslog-ng須要先安裝eventlog
  13. wget http://www.balabit.com/downloads/files/syslog-ng/sources/3.2.4/source/eventlog_0.2.12.tar.gz 
  14. #syslog-ng日誌服務器,
  15. wget http://www.balabit.com/downloads/files/syslog-ng/open-source-edition/3.3.5/source/syslog-ng_3.3.5.tar.gz 
  16. #JDK,java環境 
  17. JDK下載地址, http://www.oracle.com/technetwork/java/javase/downloads/index.html 打開此連接下載相應的jdk版本,這裏以jdk-6u21-linux-i586.bin  

二.安裝相關依賴包linux

  
  
  
  
  1. yum -y install gcc* openssl-devel glib2-devel 

三.安裝並配置mongodb數據庫
1.安裝mongodbgit

  
  
  
  
  1. useradd mongodb 
  2. mkdir -pv /data/db 
  3. chown -R mongodb:mongodb /data 
  4. tar xvf /usr/src/mongodb-linux-i686-2.2.1.tgz -C /usr/local/ 
  5. cd /usr/local/ 
  6. ln -sv mongodb-linux-i686-2.2.1 mongodb 

2.爲mongodb提供服務啓動腳本,並啓動github

  
  
  
  
  1. vim /etc/init.d/mongod  #內容以下 
  2. #!/bin/bash 
  3. # chkconfig: - 90 11 
  4. # description: mongodb server SysV script 
  5.  
  6. . /etc/rc.d/init.d/functions 
  7. if [ -f /etc/sysconfig/mongod ]; then 
  8.         . /etc/sysconfig/mongod 
  9. fi 
  10. mongod=/usr/local/mongodb/bin/mongod 
  11. prog=mongod 
  12. lockfile=/data/db/mongod.lock 
  13. RETVAL=0 
  14. OPTIONS="--fork --logpath=/data/mongod.log"   
  15.  
  16. start() { 
  17.         echo -n $"Starting $prog: " 
  18.         daemon  $mongod $OPTIONS  
  19.         RETVAL=$? 
  20.         echo 
  21.         [ $RETVAL = 0 ]  
  22.         return $RETVAL 
  23. stop() { 
  24.     echo -n $"Stopping $prog: " 
  25.     killproc -p ${lockfile}  $mongod 
  26.     RETVAL=$? 
  27.     echo 
  28.     [ $RETVAL = 0 ] && rm -f ${lockfile} 
  29. case "$1" in 
  30.   start) 
  31.     start 
  32.     ;; 
  33.   stop) 
  34.     stop 
  35.     ;; 
  36.   restart) 
  37.     stop 
  38.     start 
  39.     ;; 
  40.   status) 
  41.     status -p ${lockfile} $mongod 
  42.         RETVAL=$? 
  43.     ;; 
  44.   *) 
  45.     echo $"Usage: $prog {start|stop|restart|status|}" 
  46.     exit 1 
  47. esac 
  48. exit $RETVAL 
  49. ---------------------------------------------------- 
  50.  
  51. chmod a+x /etc/init.d/mongod 
  52. chkconfig --add mongod 
  53. chkconfig mongod on 
  54. service mongod start 

3.建立graylog2所需數據庫實例web

  
  
  
  
  1. /usr/local/mongodb/bin/mongo 
  2. >use admin 
  3. >db.addUser('admin','password') 
  4. >use graylog2 
  5. >db.addUser('graylog','redhat') 
  6. >exit 


四.安裝graylog2-server
1.安裝JDK環境mongodb

  
  
  
  
  1. cd /usr/src 
  2. chmod a+x jdk-6u21-linux-i586.bin 
  3. ./jdk-6u21-linux-i586.bin 
  4. mv jdk1.6.0_21/ /usr/local/ 
  5. cd /usr/local/ 
  6. ln -sv jdk1.6.0_21 jdk 
  7.  
  8. 添加java環境變量, 
  9. vim /etc/profile 
  10. JAVA_HOME=/usr/local/jdk 
  11. PATH=$JAVA_HOME/bin:$PATH 
  12. export JAVA_HOME PATH 
  13.  
  14. source /etc/profile 

2.安裝graylog-server數據庫

  
  
  
  
  1. cd /usr/src 
  2. tar -xvf graylog2-server-0.9.5.tar.gz -C /usr/local/ 
  3. useradd graylog 
  4. chown -R graylog:graylog /usr/local/graylog2-server-0.9.5/ 
  5. cd /usr/local 
  6. ln -sv graylog2-server-0.9.5 graylog2 
  7. cp /usr/local/graylog2/graylog2.conf.example  /etc/graylog2.conf 

3.配置garylog2-server編程

  
  
  
  
  1. vim /etc/graylog2.conf  修改內容以下 
  2. syslog_listen_port = 515    #將默認的514端口修改成其餘未使用端口,由於514端口是syslog-ng默認的端口,這裏須要用syslog-ng的514端口來接收其餘服務器發來的日誌,並進行處理的, 
  3. syslog_protocol = udp 
  4.  
  5. mongodb_useauth = true 
  6. mongodb_user = graylog2     #訪問mongodb的用戶名 
  7. mongodb_password = redhat   #訪問mongodb用戶名的密碼 
  8. mongodb_host = localhost    #mogodb的主機 
  9. mongodb_database = graylog2 #存儲日誌的數據庫 
  10. mongodb_port = 27017        #訪問mongodb的端口,默認是27017  
  11. ...... 
  12. ...... 
  13.  
  14. 爲了方便起見這裏修改下graylog-server服務啓動腳本配置文件 
  15. sed -i 's/java/$JAVA_CMD/' /usr/local/graylog2/bin/graylog2ctl 
  16. sed -i '2 aJAVA_CMD=/usr/local/jdk/bin/java' /usr/local/graylog2/bin/graylog2ctl 

4.將graylog2-server添加爲系統服務並啓動vim

  
  
  
  
  1. vim /etc/init.d/graylog2  #內容以下 
  2. #!/bin/bash 
  3. # chkconfig: - 83 19 
  4. # description: graylog2-server SysV script 
  5.  
  6. GRAYLOG_BIN=/usr/local/graylog2/bin 
  7. cd $GRAYLOG_BIN && ./graylog2ctl $1 
  8.  
  9. ------------------------------------------- 
  10. chmod a+x /etc/init.d/graylog2 
  11. chkconfig --add graylog2 
  12. chkconfig graylog2 on 
  13. service graylog2 start 

五.安裝graylog2-web-interface
1.安裝ruby腳本語言環境

  
  
  
  
  1. cd /usr/src 
  2. tar xvf yaml-0.1.4.tar.gz 
  3. cd yaml-0.1.4 
  4. ./configure --prefix=/usr/local/yaml 
  5. make 
  6. make install 
  7. cd /usr/src 
  8. tar xvf ruby-1.9.2-p0.tar.gz 
  9. cd ruby-1.9.2-p0 
  10. ./configure --prefix=/usr/local/ruby --enable-shared --disable-install-doc --with-opt-dir=/usr/local/yaml 
  11. make 
  12. make install 
  13.  
  14. vim /etc/profile 
  15. 在PATH環境變量中添加 
  16. PATH=......:/usr/local/ruby/bin 
  17.  
  18. source /etc/profile 

2.安裝graylog2-web-interface

  
  
  
  
  1. cd /usr/src 
  2. tar xvf graylog2-web-interface-0.9.5p2.tar.gz -C /usr/local/ 
  3. cd /usr/local/ 
  4. chown -R graylog:graylog /usr/local/graylog2-web-interface-0.9.5p2/ 
  5. ln -sv graylog2-web-interface-0.9.5p2/ graylog2-web-interface 
  6. cd graylog2-web-interface 
  7. gem install bundler     #須要連網 
  8. bundle install      #須要聯網 

3.配置graylog2-web-interface

  
  
  
  
  1. vim /usr/local/graylog2-web-interface/config/mongoid.yml    
  2. production: 
  3.   host: localhost   #mongodb的主機 
  4.   port: 27017       #mongodb的端口號 
  5.   username: graylog #mongodb的用戶名 
  6.   password: redhat  #mongodb的用戶名密碼 
  7.   database: graylog2    #mongodb的數據庫名 
  8.  
  9. -------------------------------------------------- 
  10. vim /usr/local/graylog2-web-interface/config/general.yml #根據本身的須要修改,不作任何修改也不要緊, 
  11. vim /usr/local/graylog2-web-interface/config/email.yml   #根據本身的須要修改,不作任何修改也不要緊,
  12.  
  13. 配置日誌切割 cat > /etc/logrotate.d/graylog2-web-interface <<EOF /usr/local/graylog2-web-interface/log/*log { size=512M rotate 90 copytruncate delaycompress compress notifempty missingok } EOF 

4.啓動graylog2-web-interface,本身能夠照着上面的服務啓動腳本的例子寫一個SysV風格的腳本

  
  
  
  
  1. cd /usr/local/graylog2-web-interface && ./script/rails server -e production & 

5.首次訪問graylog2-web界面的配置

  
  
  
  
  1. 打開瀏覽器輸入http://服務器IP:3000就打開graylog2的web界面了. 
  2. 首次使用須要作一些配置,只須要添加一個管理員賬號便可,見如下圖, 

圖1.



圖2輸入用戶信息


圖3 登陸界面


圖4 點擊messages


圖5 

能夠看到,此時尚未日誌信息,這是由於日誌的收集程序,syslog-ng尚未配置,以下

六.安裝並配置syslog-ng服務,
其實也能夠不用將syslog-ng配置成服務,graylog2也能夠經過網絡來接收日誌信息,這裏將syslog-ng配置爲服務的目的是,經過syslog-ng統一收集日誌並經過syslog-ng的強大過濾功能,能夠對本身感興趣的日誌進行過濾處理
1.安裝eventlog

  
  
  
  
  1. cd /usr/src/  
  2. tar xvf eventlog_0.2.12.tar.gz  
  3. cd eventlog-0.2.12  
  4. ./configure --prefix=/usr/local/eventlog  
  5. make  
  6. make install 

 2.安裝syslog-ng

  
  
  
  
  1. cd /usr/src  
  2. tar xvf syslog-ng_3.3.5.tar.gz  
  3. cd syslog-ng-3.3.5  
  4. export PKG_CONFIG_PATH=/usr/local/eventlog/lib/pkgconfig  
  5. ./configure --prefix=/usr/local/syslog-ng  
  6. make  
  7. make install 

3.配置syslog-ng,

  
  
  
  
  1. cat > /usr/local/syslog-ng/etc/syslog-ng.conf <<EOF 
  2. @version: 3.3  
  3. @include "scl.conf"  
  4. source s_local {  
  5.         system();  
  6.         internal();  
  7. };  
  8. #設置日誌的來源爲本機udp的514端口  
  9. source s_network { udp(ip(0.0.0.0) port(514)); };  
  10.  
  11. #將日誌發送到本機的udp515端口進行處理,515端口是graylog2-server的端口,  
  12. destination d_local { udp("127.0.0.1" port(515) ); };  
  13. log {  
  14.         source(s_local);  
  15.         source(s_network);  
  16.         destination(d_local);  
  17. };  
  18. EOF 

4.添加爲系統服務,並啓動

  
  
  
  
  1. vim /etc/init.d/syslog-ng  
  2. #!/bin/bash  
  3. #   
  4. # chkconfig: -  60 27  
  5. # description: syslog-ng SysV script.   
  6. . /etc/rc.d/init.d/functions  
  7.  
  8. syslog_ng=/usr/local/syslog-ng/sbin/syslog-ng  
  9. prog=syslog-ng  
  10. pidfile=/usr/local/syslog-ng/var/syslog-ng.pid  
  11. lockfile=/usr/local/syslog-ng/var/syslog-ng.lock  
  12. RETVAL=0 
  13. STOP_TIMEOUT=${STOP_TIMEOUT-10}  
  14.  
  15. start() {  
  16.         echo -n $"Starting $prog: "  
  17.         daemon --pidfile=$pidfile $syslog_ng $OPTIONS  
  18.         RETVAL=$?  
  19.         echo  
  20.         [ $RETVAL = 0 ] && touch ${lockfile}  
  21.         return $RETVAL  
  22. }  
  23.  
  24. stop() {  
  25.     echo -n $"Stopping $prog: "  
  26.     killproc -p $pidfile -d $STOP_TIMEOUT $syslog_ng  
  27.     RETVAL=$?  
  28.     echo  
  29.     [ $RETVAL = 0 ] && rm -f $lockfile $pidfile  
  30. }  
  31.  
  32. case "$1" in  
  33.   start)  
  34.     start  
  35.     ;;  
  36.   stop)  
  37.     stop  
  38.     ;;  
  39.   status)  
  40.         status -p $pidfile $syslog_ng  
  41.     RETVAL=$?  
  42.     ;;  
  43.   restart)  
  44.     stop  
  45.     start  
  46.     ;;  
  47.   *)  
  48.     echo $"Usage: $prog {start|stop|restart|status}"  
  49.     RETVAL=2 
  50. esac  
  51. exit $RETVAL  
  52.  
  53. ---------------------------------------  
  54.  
  55. chmod a+x /etc/init.d/syslog-ng  
  56. killall syslogd  
  57. chkconfig --add syslog-ng  
  58. chkconfig syslog-ng on  
  59. service syslog-ng start 

 七.日誌客戶端配置
1.syslog客戶端配置

  
  
  
  
  1. vim /etc/syslog.conf  
  2. *.* @服務器IP 

 2.syslog-ng客戶端配置

  
  
  
  
  1. vim "syslog-ng的配置文件"  
  2. destination d_local { udp("127.0.0.1" port(514) ); }; 

 八.測試

  
  
  
  
  1. 到這裏基本已經配置完成來,下面來測試下,在客戶端上建立一用戶,  
  2. useradd test2    
  3. 而後打開瀏覽器輸入,http://服務器IP:3000 

 圖一 用戶登陸

圖2     

能夠看到上面建立test2用戶時的日誌已經顯示出來了。到這裏配置已經結束了。
syslog及syslog-ng的詳細配置見 http://ant595.blog.51cto.com/5074217/1080922 

相關文章
相關標籤/搜索