【Perl】【IO::Socket】fork 之后 socket 连接不正常,望高人解答。

Wolf0403 2003-10-20 05:36:16
我用 perlipc 中的两个例子程序:Interactive Client with IO::Socket 和 TCP Servers with IO::Socket 来进行 Socket 编程,自己做了部分修改,但是连接不通。如果我把 client 改成单线程发送,则服务端可以收到信息。请问是怎么回事?我的系统 WinXP + ActivePerl 5.8。是不是 fork 的某些问题?
另外:无论输入什么,Server side 都没有正确匹配。是正则表达式写错了?那可是示例代码呵。。。
代码如下(只有修改的部分。未修改的部分见 perlipc 文档。)

#Client Side:

# split the program into two processes, identical twins
die "can't fork: $!" unless defined($kidpid = fork());
# the if{} block runs only in the parent process
if ($kidpid) {
print STDOUT "Chile process started now.\n";
# copy the socket to standard output
while (defined ($line = <$handle>)) {
print STDOUT $line;
}
print STDOUT "Chile process died now.\n";
kill("TERM", $kidpid); # send SIGTERM to child
}
# the else{} block runs only in the child process
else {
SendCommand(\$handle);
}

# 不通过 fork,单独调用 SendCommand 可以发送成功
sub SendCommand (\$sock_handle)
{
print STDOUT "Main process started now.\n";
# copy standard input to the socket
while (defined ($line = <STDIN>)) {
print STDOUT "Writing to socket: $line";
print $handle $line;
}
print STDOUT "Main process died now.\n";
}

#Server Side

while (<$client>) {
print "Got Msg $_"; # 加上这个,收到的时候可以直接打印
chomp $_;
next unless /\S/; # blank line
if (/\s/) { print "Space"; next;}
# ... 下同。
} continue {
print $client "Command? ";
}
close $client;

...全文
50 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
ScorpioCool 2003-10-30
  • 打赏
  • 举报
回复
Wolf0403 2003-10-30
  • 打赏
  • 举报
回复
klbt 2003-10-20
  • 打赏
  • 举报
回复
超长的问题,帮你顶。
这是一门linux下c++通讯架构实战课程,针对c/c++语言已经掌握的很熟并希望进一步深造以将来用c++在linux下从事网络通讯领域/网络服务器的开发和架构工作。这门课程学习难度颇高但也有着极其优渥的薪水(最少30K月薪,最高可达60-80K月薪),这门课程,会先从nginx源码的分析和讲解开始,逐步开始书写属于自己的高性能服务器框架代码,完善个人代码库,这些,将会是您日后能取得高薪的重要筹码。本课程原计划带着大家逐行写代码,但因为代码实在过于复杂和精细,带着写代码可能会造成每节课至少要4~5小时的超长时间,所以老师会在课前先写好代码,主要的时间花费在逐行讲解这些代码上,这一点望同学们周知。如果你觉得非要老师领着写代码才行的话,老师会觉得你当前可能学习本门课程会比较吃力,请不要购买本课程,以免听不懂课程并给老师差评,差评也会非常影响老师课程的销售并造成其他同学的误解。 这门课程要求您具备下面的技能:(1)对c/c++语言掌握的非常熟练,语言本身已经不是继续学习的障碍,并不要求您一定熟悉网络或者linux;(2)对网络通讯架构领域有兴趣、勇于挑战这个高难度的开发领域并期望用大量的付出换取高薪;在这门课程中,实现了一个完整的项目,其中包括通讯框架和业务逻辑框架,浓缩总结起来包括如下几点:(1)项目本身是一个极完整的多线程高并发的服务器程序;(2)按照包头包体格式正确的接收客户端发送过来的数据包, 完美解决收包时的数据粘包问题;(3)根据收到的包的不同来执行不同的业务处理逻辑;(4)把业务处理产生的结果数据包正确返回给客户端;本项目用到的主要开发技术和特色包括:(1)epoll高并发通讯技术,用到的触发模式是epoll中的水平触发模式【LT】;(2)自己写了一套线程池来处理业务逻辑,调用适当的业务逻辑处理函数处理业务并返回给客户端处理结果;(3)线程之间的同步技术包括互斥量,信号量等等;(4)连接池中连接的延迟回收技术,这是整个项目中的精华技术,极大程度上消除诸多导致服务器程序工作不稳定的因素;(5)专门处理数据发送的一整套数据发送逻辑以及对应的发送线程;(6)其他次要技术,包括信号、日志打印、fork()子进程、守护进程等等;

37,720

社区成员

发帖
与我相关
我的任务
社区描述
JavaScript,VBScript,AngleScript,ActionScript,Shell,Perl,Ruby,Lua,Tcl,Scala,MaxScript 等脚本语言交流。
社区管理员
  • 脚本语言(Perl/Python)社区
  • IT.BOB
加入社区
  • 近7日
  • 近30日
  • 至今

试试用AI创作助手写篇文章吧