socket_accept以后,直接调用
pnctl_fork不知道在windows下能不能用.
不过返回不是0的那个进程并不是这样就完事了,还要调用pcntl_wait防止子进程卡在那边没有完全结束.你可以在主进程里时不时就调用这个,配上WNOHANG作为option参数防止没有子进程需要wait的时候卡在那边.
这都是linux下常用的处理手段.说实话本来我想让你用多线程的,不过看了一圈不知道php里怎么用线程,倒是找到了用进程的方式,所以就
php实现ios推送的方法:首先把要发送的消息以及iPhone标识打包,并发送给APNS;然后查找有相应标识的iPhone,并把消息发送到iPhone;最后把发来的消息传递给相应的应用程序,并且按照设定弹出Push通知即可.
可以分为三个阶段:
第一阶段:应用程序把要发送的消息、目的iPhone的标识打包,发给APNS.
第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发送到iPhone.
第三阶段:iPhone把发来的消息传递给相应的应用程序,并且按照设定弹出Push通知.
在php中用百度云推送进行消息的推送的方法
①Android端推送
// 创建Android SDK对象.
$asdk = new \Vendor\pushsdk\PushSDK(); //自己引入百度云推送的SDK,官网上有文档详细介绍
$channelId = $channelrows;
$message = array (
// 消息的标题.
'title' = $title,
// 消息内容
'description' = $brief,
//传广告id,可以通过键值对的形式传多个值
'custom_content'=array('id'=$id),
);
// 设置消息类型为通知类型.
$opts = array (
'msg_type' = 1,
// 向目标设备发送一条消息(群发,指的是通过前面的筛选之后的channelId进行的大量的推送)
$rs = $asdk - pushBatchUniMsg($channelId, $message, $opts);
// 判断返回值,当发送失败时, $rs的结果为false, 可以通过getError来获得错误信息.
if($rs === false)
{
print_r($asdk-getLastErrorCode());
print_r($asdk-getLastErrorMsg());
}
else{echo "success!";}
// 创建Ios SDK对象.
$isdk = new \Vendor\ipushsdk\IPushSDK();
'aps' = array(
'alert' = $brief, // 消息内容
),
'id' =$id, //账号ID,这边能够以键值对的形式可以传多个值
// 设置消息类型为 通知类型.
msg_type' = 1,
$rs = $isdk-createTag('tag_new'); //通过创建标签的方式来实现群发的功能
if($rs !== false)
if($isdk - addDevicesToTag('tag_new',$channelId) !== false)
// 发送
$rs = $isdk - pushMsgToTag('tag_new',$message,$opts);
//删除标签
$delRs = $isdk-deleteTag('tag_new');
//判断返回值,当发送失败时, $rs的结果为false, 可以通过getError来获得错误信息.
print_r($isdk-getLastErrorCode());
print_r($isdk-getLastErrorMsg());
后端代码
push.php
php
use?Workerman\Worker;
require_once?'./Workerman/Autoloader.php';
//?这里进程数必须设置为1
$worker-count?=?1;
//?worker进程启动后建立一个内部通讯端口
$worker-onWorkerStart?=?function($worker)
//?开启一个内部端口,方便内部系统推送数据,Text协议格式?文本+换行符
$inner_text_worker-onMessage?=?function($connection,?$buffer)
global?$worker;
//?$data数组格式,里面有uid,表示向那个uid的页面推送数据
$data?=?json_decode($buffer,?true);
$uid?=?$data['uid'];
//?通过workerman,向uid的页面推送数据
$ret?=?sendMessageByUid($uid,?$buffer);
//?返回推送结果
$connection-send($ret?'ok'?:?'fail');
};
$inner_text_worker-listen();
//?新增加一个属性,用来保存uid到connection的映射
$worker-uidConnections?=?array();
$worker-onMessage?=?function($connection,?$data)use($worker)
if(!isset($connection-uid))
//?没验证的话把第一个包当做uid(这里为了方便演示,没做真正的验证)
$connection-uid?=?$data;
/*?保存uid到connection的映射,这样可以方便的通过uid查找connection,
*?实现针对特定uid推送数据
*/
$worker-uidConnections[$connection-uid]?=?$connection;
return;
$worker-onClose?=?function($connection)use($worker)
if(isset($connection-uid))
//?连接断开时删除映射
unset($worker-uidConnections[$connection-uid]);
//?向所有验证的用户推送数据
function?broadcast($message)
foreach($worker-uidConnections?as?$connection)
$connection-send($message);
//?针对uid推送数据
function?sendMessageByUid($uid,?$message)
if(isset($worker-uidConnections[$uid]))
$connection?=?$worker-uidConnections[$uid];
return?true;
return?false;
//?运行所有的worker(其实当前只定义了一个)
Worker::runAll();
启动后端服务
php?push.php?start?-d
前端接收推送的js代码
ws.onopen?=?function(){
var?uid?=?'uid1';
ws.send(uid);
ws.onmessage?=?function(e){
alert(e.data);
后端推送消息的代码
//?建立socket连接到内部推送端口
//?推送的数据,包含uid字段,表示是给这个uid推送
fwrite($client,?json_encode($data)."\n");
//?读取推送结果
这里的uid不一定是用户的id,也可以理解为任务id即 taskid
以上代码亲测可以直接使用
①.、php+redis 消息队列
想玩并发的话,php 的话除了 pcntl_fork 多个进程跑脚本,本身有批处理的模块,可以用 curl_multi_* 批量发送
第一段:socket协议的简介
WebSocket是什么,有什么优点
WebSocket是一个持久化的协议,这是相对于http非持久化来说的.应用层协议
举个简单的例子,http1.0的生命周期是以request作为界定的,也就是一个request,一个response,对于http来说,本次client与server的会话到此结束;而在http1.1中,稍微有所改进,即添加了keep-alive,也就是在一个http连接中可以进行多个request请求和多个response接受操作.然而在实时通信中,并没有多大的作用,http只能由client发起请求,server才能返回信息,即server不能主动向client推送信息,无法满足实时通信的要求.而WebSocket可以进行持久化连接,即client只需进行一次握手,成功后即可持续进行数据通信,值得关注的是WebSocket实现client与server之间全双工通信,即server端有数据更新时可以主动推送给client端.
第二段:介绍client与server之间的socket连接原理
①.、下面是一个演示client和server之间建立WebSocket连接时握手部分
a、client建立WebSocket时向服务器端请求的信息
GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket //告诉服务器现在发送的是WebSocket协议
Connection: Upgrade
Sec-WebSocket-Protocol: chat, superchat
Origin:
b、服务器获取到client请求的信息后,根据WebSocket协议对数据进行处理并返回,其中要对Sec-WebSocket-Key进行加密等操作
HTTP/1.1 101 Switching Protocols
Sec-WebSocket-Protocol: chat
第三段:PHP中建立websocket的过程讲解
SocketService.php:
web.html: