perl 采集数据写入数据库
来源:互联网 发布:测试颜值的软件 编辑:程序博客网 时间:2024/04/29 23:42
<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_file\n";print "\######监控服务器: $IPMACHINE\n";print "\######报警通知腾讯通号码: $RTXNO\n";print "\######当前报警时间戳: $SDATE\n";##########监控关键字,以空格隔开################@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\"---数量=$count\n"; 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_info\n"; $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 ("$i\n");};
0 0
- perl 采集数据写入数据库
- Perl 采集监控日志插入数据库
- 数据库数据采集总结
- Perl读写数据库数据
- xml 数据 写入 数据库 转帖
- 将二进制数据写入数据库
- flex往数据库写入数据
- java数据写入数据库错误
- tushare数据写入SQLite 数据库
- discuz数据库写入数据发帖
- 将大数据写入数据库
- Perl 采集磁盘信息
- Perl 采集内存
- 大型数据库数据采集方法简介(2)
- 大型数据库数据采集方法简介(3)
- 数据库系统io相关数据采集
- perl 写入到压缩文件
- DataTable的数据批量写入数据库
- 面试题8 旋转数组的最小数字
- 【Rayeager PX2】andoid开机logo分析及PX上的实现
- JavaScript概念之screen/client/offset/scroll/inner/avail的width/left
- 第2章 14
- 科。学。上。网。
- perl 采集数据写入数据库
- jsp与javaBean的使用
- android耗时任务_HandlerThread
- Android-View事件处理机制
- PullToRefreshScrollView嵌套SwipeMenuListView冲突问题解决
- linux下可执行程序如何定位共享库文件以及如何让系统找到用户指定的库
- redis集合类型
- yum只下载软件不安装的两种方法
- Android中解析Json——Jackson使用