mysql - perl tcp 套接字服务器到 mysql

标签 mysql perl sockets tcp

我必须创建一个小的 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();

最佳答案

你的问题不止一个,我来回答第二个:这里是获取所有数据的方法。

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)
{
...
}

关于mysql - perl tcp 套接字服务器到 mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23648711/

相关文章:

mysql - 我无法克服子查询返回多于一行的问题

c - 是否可以将结构转换为另一个结构?

javascript - Socket.io:接收事件触发多次

python - 如何将数字更改为科学数字并获得最小值(科学数字格式)

javascript - npm 在 Windows 10 Insider Preview 版本 14366 上失败

mysql - 从零减去在查询中不起作用

javascript - 使用javascript在php中准备在线测试

php - 使用 php lastInsertId() 将一个表中的主键作为外键插入到另一个表中

perl - 如何创建在不同标量上下文中返回不同值的对象?

perl - 如何重构 for 循环中发生的递归以使其成为尾调用?