我必须创建一个小Perl脚本,它创建一个TCP套接字,并将这个套接字的输入放到一个MySQL表中。
背景:我通过这个TCP接口从西门子HiPath电话系统获取通话数据记录。
我必须写数据,这是一个数据库中的csv,以备将来使用。
我得到的格式如下:13.05.14;15:01:14;3;10;00:26;00:00:45;0123456789;;1;
我是Perl新手,有几个“noob”问题:)
1:如何在后台运行该脚本(作为守护者)?
2:脚本只处理deliverd csv行的最后一行。如果有两行,则忽略第一行。我该怎么解决?
3:今天我从脚本中得到了这个输出:dbd::mysql::st execute failed:mysql server已经离开了./hipath-cdr-server.pl第41行。那里发生了什么事?
有人能帮我解答这个简单的问题吗?
这就是我现在所得到的:
#!/usr/bin/perl
use strict;
use warnings;
use DBI;
use IO::Socket::INET;
my $dbh = DBI->connect('DBI:mysql:database=hipathCDR;host=localhost','***','***',{ RaiseError => 1, AutoCommit => 1 }, );
my $sql = 'INSERT INTO calls (Datum,Zeit,Leitung,Teilnehmer,Rufzeit,Gespraechszeit,RufNr,Gebuehr,Typ) VALUES (?,?,?,?,?,?,?,?,?)';
my $sth = $dbh->prepare($sql);
# auto-flush on socket
$| = 1;
# creating a listening socket
my $socket = new IO::Socket::INET (
LocalHost => '0.0.0.0',
LocalPort => '4444',
Proto => 'tcp',
Listen => 5,
Reuse => 1
);
die "cannot create socket $!\n" unless $socket;
while(1)
{
# waiting for a new client connection
my $client_socket = $socket->accept();
# get information about a newly connected client
my $client_address = $client_socket->peerhost();
my $client_port = $client_socket->peerport();
# read up to 1024 characters from the connected client
my $data = "";
$client_socket->recv($data, 1024);
chomp ($data);
my @values = split(';', $data);
print "Array: @values\n";
$sth->execute(@values);
# write response data to the connected client
$data = "ok";
$client_socket->send($data);
# notify client that response has been sent
shutdown($client_socket, 1);
}
$socket->close();
最佳答案
你有不止一个问题,我要回答第二个问题:这里是如何获取所有数据。
my $data = "";
while ($client_socket->recv($data, 1024)){
$data .= $_;
}
用text::csv解析传入的类似csv的数据会更安全。
问题三的答案:
很可能那时你的mysql不可用。
第一个问题的答案:
nohup ./script.pl &
好吧,我只是开玩笑:How can I run a Perl script as a system daemon in linux?
use Proc::Daemon;
Proc::Daemon::Init;
my $continue = 1;
$SIG{TERM} = sub { $continue = 0 };
...
while($continue)
{
...
}