perl 采集数据写入数据库
发布时间:2020-12-15 23:44:07 所属栏目:大数据 来源:网络整理
导读:pre name="code" class="sql"#!/usr/bin/perl use POSIX;use CGI;use DBI; my $dbName = 'oadb'; my $dbUser = 'system'; my $dbUserPass = 'a2xxxxxmvh'; my $dbh = DBI-connect("dbi:Oracle:$dbName",$dbUser,$dbUserPass) or die "can't connect to datab
<pre name="code" class="sql">#!/usr/bin/perl use POSIX; use CGI; use DBI; my $dbName = 'oadb'; my $dbUser = 'system'; my $dbUserPass = 'a2xxxxxmvh'; my $dbh = DBI->connect("dbi:Oracle:$dbName",$dbUser,$dbUserPass) or die "can't connect to database " ; my $dir = '/usr/local/apache-tomcat-7.0.55_8081/logs'; my $file = 'catalina.out'; my $tom_home='/usr/local/apache-tomcat-7.0.55_8081/webapps/mon'; $mon_file = "$dir/$file"; $IPMACHINE = "MBANKtest1"; $RTXNO="04657"; my $SDATE = strftime("%Y%m%d%H%M%S",localtime()); $UPLOADPATH = "/data/swap/mbanklog/$IPMACHINE-$SDATE$file"; print "########################################################################################################################n"; print "######监控日志文件: $mon_filen"; print "######监控服务器: $IPMACHINEn"; print "######报警通知腾讯通号码: $RTXNOn"; print "######当前报警时间戳: $SDATEn"; ##########监控关键字,以空格隔开################ @warn_arr = qw/Exception 登录失败 登陆失败 用户名或密码错误/; if (-f "$tom_home/file.html"){ open FILE,">$tom_home/file.html"; close FILE;}; foreach $a (@warn_arr) { undef @err_info; open( C,"<","$a.tmp" ); while (<C>) { $count = $_; } print "=========================================================================================================================n"; print "######监控异常关键字: "$a"---数量=$countn"; open( A,"$mon_file" ) || die "$!n"; $i = 0; $num = 0; $b = 0; #$b是取得最后一行匹配关键字的行号 while (<A>) { $num++; if ( $_ =~ /$a/i ) { $i++; $b = $num } }; #defined($count) 是第一次读取文件时为空 $i!=0 是累计次数不为0 防止文件清空的情况 if ( $i != 0 && $i != $count && defined($count) ) { open( B,"$mon_file" ) || die "$!n"; while (<B>) { if (($. >= "$b" -1) and ($. <= "$b" + 1) ) {push( @err_info,$_ ); if ($_ =~ /.*username=(.*?)&password.*/){$USER=$1}; }; }; close B; print "######错误信息:@err_infon"; $dbh->do("INSERT INTO SYSTEM.ERR_INFO values('$USER','11.4.19.62',to_date('$SDATE','yyyy-mm-dd hh24:mi:ss'),'@err_info')") or die($DBI::errstr); }; open( D,">","$a.tmp" ); print D ("$in"); }; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |