Linux查看被拦截的日志,imperva拦截日志的实时报警

1)  imperva拦截是默认会发送一个错误页面给client,response code 为200,可以通过F5来抓这个错误页面来判断是否发生了block,并且取得相关信息。为了区分修改response code为210,在错误页面里插入imperva生成的Event ID.用分号区分

Error

Error

Error
This page can't be displayed. Contact support for additional information.
;

Event id: $(EVENT_ID);

Session id: $(SESSION_ID).

2)  在F5上设置irules来抓取response 为210的代码,并且通过分离;在http payload抓取Event id的值,和客户端IP+port,以local5的类型生成log

when HTTP_RESPONSE {

if { [HTTP::status] equals "210" } {

set event [lindex [split [HTTP::payload] ";"] 1]

log local5. "$event DIP:[IP::local_addr]:[TCP::local_port]"

}

}

3)   下面需要一台linux服务器来做日志服务器,并用SHELL进行实时报警

l  编辑/etc/sysconfig/syslog文件

在“SYSLOGD_OPTIONS”行上加“-r”选项以允许接受外来日志消息

如果不想让中央日志服务器解析其他机器的FQDN,还可以加上“-x”选项

SYSLOGD_OPTIONS="-r -x -m 0"

l  重新启动syslog守护进程

/etc/init.d/syslog restart

如果启动失败可以查看该文件的加载项是否都满足,

vi  /etc/init.d/syslog  和vi /etc/sysconfig/syslog-ng

查看以下文件是否都存在,不存在会导致进程无法启动,可以手动添加syslog.pid进程ID

SYSLOGNG_PREFIX=/opt/syslog-ng

SYSLOGNG="$SYSLOGNG_PREFIX/sbin/syslog-ng"

CONFFILE=$SYSLOGNG_PREFIX/etc/syslog-ng.conf

PIDFILE=$SYSLOGNG_PREFIX/var/run/syslog-ng.pid

SYSLOGPIDFILE="/var/run/syslog.pid"

l  启动进程成功后看查看netstat –tunlp查看是否有监听udp 514端口,然后在iptables 里面加入允许udp 514的访问

Vi  /etc/sysconfig/iptables

-A RH-Firewall-1-INPUT -p udp -m udp --dport 514 -j ACCEPT

Service iptables restart

l   设置F5发过来的log保存到哪个文件

Vi  /etc/syslog.conf

设置local5类型的log保存到f5.log中

# Save Debug Message of f5 to f5.log

local5.*                                                  /var/log/f5.log

设置local5类型的log不保存到messages中

*.info;mail.none;authpriv.none;cron.none;local5.none            /var/log/messages

l  设置logrotate,自动每天都打包日志文件,保存10份

vi /etc/logrotate.conf 加入

/var/log/f5.log {

daily

compress

rotate 10

}

重启进程 /etc/init.d/syslog restart

4)  设置sendmail实时邮件报警

l  修改配置文件支持发送

Vi  /etc/mail/sendmail.cf

将O DaemonPortOptions =Port=smtp,Addr=127.0.0.1, Name=MTA

改为O DaemonPortOptions =Port=smtp, Name=MTA

然后重启sendmail

/etc/init.d/sendmail restart

l  设置SHELL脚本来根据log情况来发自动邮件,根据时间每10秒中读取1次f5.log,对比前后的差别,如果有新的log就把这个不同的log当作正文发送邮件,这里的需要设置NTP来保持各个设备时间的一致性,因为每条log都有时间戳,所以用date来命令来读取最近的日志,这样的方式基本可以既不遗漏又不重复的取到每一条新来的log,适用于log量比较大的情况。

#!/bin/bash

while true; do

A=`date +%H:%M |awk '{print substr($0,1,4)}'`

tail /var/log/f5.log |grep "$A" > file1.txt

sleep 10

tail /var/log/f5.log |grep "$A" > file2.txt

diff file1.txt file2.txt > file.diff

if [ -s file.diff ]; then

mail -s "alert mail" tony.yu@abc.com < file.diff

fi

done

l  后台不间断执行

nohup ./mail.sh > /dev/null 2>&1 &

l  设置outlook,每分钟收邮件,有log邮件自动提示

工具—选项—邮件设置---发送/接收—自动发送接收时间间隔1分钟

工具---规则和通知---更改规则---在新邮件通知窗口中显示(如果需要把log邮件放在自建的目录才需要,默认在收件箱会有桌面通知)

5)  设置飞信机器人实时报警

参考资料 http://bbs.it-adv.net/viewthread.php?tid=1081

l  下载飞信机器人和支持库

Wget http://bbs.it-adv.net/attachment.php?aid=43&k=99987835a1dcf27b177fcaa6dd5b2f2e&t=1305267611

Wget  http://www.it-adv.net/fetion/cenos54X64_20101113.rar

l  把飞信机器人和支持库都放在同一个目录/usr/local/fetion, 复制部分支持库到/lib才能正常使用, 运行./fetion 不报错就行了

cp /usr/loca/fetion/libACE-5.7.2.so /lib/

cp /usr/loca/fetion/libACE_SSL-5.7.2.so /lib/

cp /usr/loca/fetion/libcrypto.so.4 /lib/

cp /usr/loca/fetion/libssl.so.4 /lib/

l  尝试发送测试飞信信息

./fetion --mobile=135xxxxxx --pwd=xxxxxx --to=139xxxxxxxx --msg-type=2 --msg-utf8=test –debug

第一次会生成135xxxxxxxx.jpg的验证码图片,需要用WINSCP等工具下载到window下查看图片,然后输入验证码才能使用.

注意点:第一次不要加入--exit-on-verifycode=1参数,否则生成验证码图片会有问题

如果验证码问题一直存在,则可以用飞信机器人的服务模式,一直在线,但需要插件支持。

l  测试成功后就可以加入到刚才的mail.sh脚本中使用

#!/bin/bash

while true; do

M="135xxxxxx"

P="xxxxxx"

T="139xxxxxx"

A=`date +%H:%M |awk '{print substr($0,1,4)}'`

tail /var/log/f5.log |grep "$A" > file1.txt

sleep 10

tail /var/log/f5.log |grep "$A" > file2.txt

diff file1.txt file2.txt > file.diff

B=`cat file.diff`

if [ -s file.diff ]; then

/usr/local/fetion/fetion --mobile="$M" --pwd="$P" --to="$T" --exit-on-verifycode=1 --msg-type=2 --msg-utf8="$B" >/dev/null 2>&1

mail -s "alert mail" tony.yu@abc.com < file.diff

fi

done

亿恩科技地址(ADD):郑州市黄河路129号天一大厦608室 邮编(ZIP):450008 传真(FAX):0371-60123888

联系:亿恩小凡

QQ:89317007

电话:0371-63322206

本文出自:亿恩科技【www.enkj.com】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值