- 论坛徽章:
- 2
|
本帖最后由 os4fun 于 2014-07-28 16:27 编辑
打算弄个简单的c/s跑个小东西,几行代码的小demo也要坚定的出错啊:wink:
c从s读取时间。
c 串行读取的时候一切正常。
c 多线程,部分连接读不到任何东西。ARGV[0]越大,失败越多。
两边warn出来的信息看,双方都认为连接出了问题。
我甚至上了wireshark ,所有的连接都成功建立。问题连接还没传送任何东西就被 s 主动关闭。c自然读不到,s也写不出去。
--udpate--
原因找到,很弱智. srv:- for (my $i = 0;; $i++) {
- $cli = $socket->accept or die $!;
- #这里的$cli生命期仅仅在这次循环里,下次循环的时候$cli被重新赋值,上一次的值会被释放,也就是句柄被放掉了.
- $tp->add(fileno($cli), $i);
- }
复制代码 -------- #!/usr/bin/perl -w
- # cli
- use 5.010;
- use strict;
- use IO::Socket;
- use Thread::Pool::Simple;
- sub get_date {
- my $socket = new IO::Socket::INET( PeerAddr => '127.0.0.1:9000') or warn $!;
- #sleep 1;
- say shift, (<$socket> or warn $!); #Warning: something's wrong
- }
- #get_date($_) for (0 .. $ARGV[0] || 10);
- my$tp = Thread::Pool::Simple->new(min=>10,max=>20,load=>10,do=>[\&get_date]);
- $tp->add($_) for (0 .. $ARGV[0] || 10);
- $tp->join();
复制代码- #!/usr/bin/perl -w
- # srv
- use 5.010;
- use strict;
- use POSIX;
- use IO::Socket;
- use Thread::Pool::Simple;
- my $socket = new IO::Socket::INET(LocalAddr=>'127.0.0.1:9000', Listen=>10, Reuse=>1) or die $!;
- sub day_svc {
- my ($fileno, $i) = @_;
- open my $cli, ">&=$fileno" or warn $!; #warn:Bad file descriptor
- print $cli scalar localtime; #warn:print() on closed filehandle
- close $cli;
- POSIX::close $fileno;
- say "$i done";
- }
- my $tp = Thread::Pool::Simple->new(min=>30,max=>50,load=>10,do=>[\&day_svc]);
- my $cli;
- for (my $i = 0;; $i++) {
- $cli = $socket->accept or die $!;
- $tp->add(fileno($cli), $i);
- }
- $tp->join();
复制代码 |
|