设为首页 收藏本站
查看: 404|回复: 0

[经验分享] 万恶的单线程!!怎样才能实现一个真正的多线程的php socket server啊!!!

[复制链接]

尚未签到

发表于 2015-8-27 09:10:56 | 显示全部楼层 |阅读模式
  想用php来做socket服务,因为http协议效率实在太低了
网上找来代码,调试好之后,发现即使能两个客户端同时连接上,服务端在处理一个客户端请求时
另外一个客户端的请求被阻塞了,只有等到前一个客户端的事情处理完了,后一个客户端的请求才会被响应!

server.php


PHP code


<?php
$addr = "127.0.0.1";
$port = 1000;
$remoteIP = "";
$remotePort = "";
$socket = socket_create(AF_INET,SOCK_STREAM,SOL_TCP);
if($socket < 0) {
echo "Socket create:".$socket_strerror($socket)."/n";
exit;
}
if ( ($ret = socket_bind($socket, $addr, $port)) < 0 ) {
echo "socket bind:".socket_strerror()."/n";
exit;
}
if ( ($ret = socket_listen($socket, 5)) < 0 ) {
echo "socket listen:".socket_strerror()."/n";
exit;
}
socket_set_nonblock($socket);
echo "Wainting fro a connection:/n";
$clients = array($socket);
while(true) {
$read = $clients;
if(socket_select($read, $writes=NULL, $execs=NULL, 3) < 1){
//echo ".";
        continue;
}
if(in_array($socket,$read)) {
$clients[] = $newsock = socket_accept($socket);
socket_set_nonblock($newsock);
socket_getpeername($newsock,&$remoteIP,&$remotePort);        
$key = array_search($socket,$read);
unset($read[$key]);
$msg = "Server: $addr/r/n".
"Notice:Welcome the user from ".$remoteIP.":".$remotePort."./r/n";
echo $remoteIP.":".$remotePort." conected in./r/n";
socket_write($newsock,$msg);
}
foreach($read as $read_sock) {
$data = @socket_read($read_sock,1024,PHP_BINARY_READ);
if($data == false) {
$key = array_search($read_sock,$clients);
print_r($clients[$key]);
unset($clients[$key]);
socket_close($read_sock);
echo "Client disconnected./n";
continue;
}
$command = strtoupper ($data);
switch ($command)
{
case "LIST":
$writer = print_r($clients,1);
break;
case "HELLO":
$writer = "Hello Everybody!";
break;
case "QUIT":
$writer = "Bye-Bye";
break;
case "SLEEP":
sleep(30);
$writer = "sleeped 10 seconds!";
break;
case "HELP":
$writer = "HELLO/tQUIT/tHELP";
break;
default:
$writer = "Error Command!/r/nType help for help message!";
}
socket_write($read_sock, $writer);
//exit;
    }
}
socket_close($socket);
?>


  
client.php


PHP code


<?php
// Client
// 设置错误处理
error_reporting (E_ALL);
// 设置处理时间
set_time_limit (0);
$ip = "127.0.0.1";       // IP 地址
$port = 1000;            // 端口号

$socket = socket_create (AF_INET, SOCK_STREAM, SOL_TCP);   // 创建一个SOCKET
if ($socket)
echo "socket_create() successed!/n";
else
echo "socket_create() failed:".socket_strerror ($socket)."/n";
$conn = socket_connect ($socket, $ip, $port);       // 建立SOCKET的连接
if ($conn)
echo "Success to connection![".$ip.":".$port."]/n";
else
echo "socket_connect() failed:".socket_strerror ($conn)."/n";
echo socket_read ($socket, 1024);   
$stdin = fopen ('php://stdin', 'r');
while (true)
{
$command = trim (fgets ($stdin, 1024));
socket_write ($socket, $command, strlen ($command));
$msg = trim (socket_read ($socket, 1024));
echo $msg."/n";
if ($msg == "Bye-Bye")
break;
}
fclose ($stdin);
socket_close ($socket);
?>


  
第一个客户端连接上后输入命令sleep,迫使服务器端持续处理第一个客户端的请求,第二个客户端连接能成功连接,但是得不到响应,如果不使用sleep,两个客户端看起来都能和服务器端正常通讯,不知道谁有办法解决这个问题没有.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-104798-1-1.html 上篇帖子: 【转】php判断操作系统或浏览器 下篇帖子: php简单数据缓存类
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表