Perl TCP套接字服务器到MySQL

3

我需要创建一个小的Perl脚本,它会创建一个TCP套接字,并将从此套接字输入的内容放入MySQL表中。

背景:我通过这个TCP套接字从Siemens Hipath电话系统获取呼叫数据记录。我必须将这些CSV格式的数据写入数据库以备将来使用。我收到的格式如下:13.05.14;15:01:14;3;10;00:26;00:00:45;0123456789;;1;

我是Perl的新手,有一些“初学者”问题: 1:如何将该脚本作为守护进程在后台运行? 2:该脚本仅处理交付的CSV行的最后一行。如果有两行,则忽略第一行。如何解决这个问题? 3:今天我从我的脚本中得到了这个输出:DBD::mysql::st execute failed: MySQL server has gone away at ./hipath-CDR-Server.pl line 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();

我已经从帖子中删除了你的密码。 - user1126070
1个回答

0

您有多个问题,我将回答第二个:以下是获取所有数据的方法。

my $data = "";
while ($client_socket->recv($data, 1024)){
  $data .= $_;
}

使用 Text::CSV 解析传入的 CSV 数据更安全。

回答第三个问题:

很可能您的 mysql 当时不可用。

回答第一个问题:

nohup ./script.pl &

好的,我只是开玩笑:如何在Linux中将Perl脚本作为系统守护进程运行?

use Proc::Daemon;

Proc::Daemon::Init;

my $continue = 1;
$SIG{TERM} = sub { $continue = 0 };
...
while($continue)
{
...
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接