如何使用perl加载带有日志文件条目的SQLite3数据库

时间:2013-04-05 05:45:57

标签: database perl module sqlite dbi

我有一个赋值在我的Perl类中包含两个程序,第一个是使用DBI :: SQLite for Perl创建数据库和表,我已经完成了程序的第一部分,但我不知道如何去做第二部分。第二部分涉及从日志文件中获取源IP和目标端口对,并使用SQL insert语句将它们插入到表中。在第一个程序中创建的表包含两列,一列用于源IP,另一列用于目标端口,除了添加到表中的行数之外,程序不应产生任何输出。正如您在下面看到的,我所放置的代码代表了表的设置方式,我真的很感谢学习如何填表。第二个程序所需的日志文件可从此链接获得:http://fleming0.flemingc.on.ca/~chbaker/COMP234-Perl/sample.log

我的第一个程序的代码

#!/usr/bin/perl

use strict;
use warnings;
use DBI;

my $dbh = DBI->connect(          
    "dbi:SQLite:dbname=test.db", 
    "",
    "",
    { RaiseError => 1}
) or die $DBI::errstr;
$dbh->do(<<'END_SQL');
CREATE TABLE probes (
    source CHAR(15) NOT NULL,
    port CHAR(5) NOT NULL,
    PRIMARY KEY (source, port) )
END_SQL

第二个程序的代码(没有运作)

#!/usr/bin/perl

use strict;
use warnings;
use DBI;

my %ip2port;
my $IPCount = keys %ip2port;
my $portCount = 0;
my $filename = "./sample.log";
open my $LOG, "<", $filename or die "Can't open $filename: $!";
LINE: while (my $line = <$LOG>) {
my ($src_id) = $line =~ m!SRC=([.\d]+)!gis; my ($dst_port) = $line =~ m!DPT=([.\d]+)!gis;
my $dbh = DBI->connect(          
    "dbi:SQLite:dbname=test.db", 
    "",                          
    "",                          
    { RaiseError => 1 },         
) or die $DBI::errstr;


$dbh->do("INSERT INTO probes VALUES($src_id, $dst_port )");
$dbh->do("INSERT INTO probes VALUES(2,'$dst_port',57127)");
my $sth = $dbh->prepare("SELECT SQLITE_VERSION()");
$sth->execute();

my $ver = $sth->fetch();

print @$ver;
print "\n";

$sth->finish();
$dbh->disconnect();
}

1 个答案:

答案 0 :(得分:0)

逐行阅读文件(网上有几十个例子)。

my ($src_id) = $line =~ m!SRC=([\.\d]+)!gis;
my ($dst_port) = $line =~ m!DPT=([\.\d]+)!gis;

然后将此数据插入数据库。 (网上有几十个例子。)

一些阅读:http://www.perl.com/pub/1999/10/DBI.html