文档章节

swoole简单的流程图(Worker的分配)

304158
 304158
发布于 2017/06/27 18:06
字数 292
阅读 303
收藏 0

 WorkerStart 的回调

$serv->on('WorkerStart',function ($serv,$worker_id){
        echo "启动了一个Worker";
    });

 

Worker进程的任务分配模式是?

worker进程数据包分配模式

dispatch_mode = 1 //1平均分配,2按FD取摸固定分配,3抢占式分配,默认为取模(dispatch=2)

抢占式分配,每次都是空闲的worker进程获得数据。很合适SOA/RPC类的内部服务框架
当选择为dispatch=3抢占模式时,worker进程内发生onConnect/onReceive/onClose/onTimer会将worker进程标记为忙,不再接受新的请求。reactor会将新请求投递给其他状态为闲的worker进程
如果希望每个连接的数据分配给固定的worker进程,dispatch_mode需要设置为2

$serv->on('receive', function ($serv, $fd, $from_id, $data) {//接收到来自客户端信息的回调
        $serv->send($fd, 'Swoole: '.$data);
        $serv->tick(1000, function() use ($serv, $fd) {
            $serv->send($fd, $serv->worker_id);

        });
    });
/*向客户端发送当前worker的ID,在设置为平均分配时,测试可以开启两个客户端,非常明显的就可以看出
是两个不同的worker进程发来的信息    $serv->send($fd, $serv->worker_id);*/

© 著作权归作者所有

共有 人打赏支持
304158
粉丝 1
博文 105
码字总数 30016
作品 0
大兴安岭
私信 提问
基于SWOOLE的分布式SOCKET消息服务器架构

消息服务器使用socket,为避免服务器过载,单台只允许500个socket连接,当一台不够的时候,扩充消息服务器是必然,问题来了,如何让链接在不同消息服务器上的用户可以实现消息发送呢? 要实现...

tomener
2016/06/16
339
0
swoole-1.7.16 版本已发布,BUG 修复版本

PHP的异步并行网络扩展 swoole1.7.16 版本已发布,此版本为BUG修复版本,建议所有用户升级。下载地址: http://pecl.php.net/package/swoole https://github.com/swoole/swoole-src/releases...

matyhtf
2015/05/11
2.1K
28
swoole-1.7.8 已发布,建议所有用户升级

swoole-1.7.8 已发布,此版本为BUG修复版本,建议所有用户升级。 主要更新: 修复swoole_http_server::on未执行父类方法的问题 修复swoole_http_server中COOKIE无法读取的问题 增加swoole_ht...

matyhtf
2014/11/26
2.4K
7
Swoole 1.10.0 发布,增加多项新特性

PHP的异步、并行、高性能网络通信引擎 Swoole 已发布 1.10.0 版本。此版本增加了多项新特性。 自动 DNS 解析 新版本的异步客户端不再需要使用 swoole_async_dns_lookup 解析域名了,底层实现...

matyhtf
2018/01/08
986
11
swoole 在 swoft 中的应用

date: 2017-12-14 21:34:51 title: swoole 在 swoft 中的应用 swoft 官网: https://www.swoft.org/ swoft 源码解读: http://naotu.baidu.com/file/814e81c9781b733e04218ac7a0494e2a?token=......

daydaygo
2017/12/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

tac 与cat

tac从后往前看文件,结合grep使用

writeademo
今天
2
0
表单中readonly和dsabled的区别

这两种写法都会使显示出来的文本框不能输入文字, 但disabled会使文本框变灰,而且通过通过表单提交时,获取不到文本框中的value值(如果有的话), 而readonly只是使文本框不能输入,外观没...

少年已不再年少
今天
2
0
SpringBoot上传图片操作

首先有个上传文件的工具类 /** * 文件上传 * @param file * @param filePath * @param fileName * @throws Exception */public static void uploadFile(byte[] file, String ...

_liucui_
今天
6
0
DrawerLayout

public class MainActivity extends BaseActivity implements NavigationView.OnNavigationItemSelectedListener,OnFragmentInteractionListener{ public NavigationView navView; ......

安卓工程师王恒
今天
2
0
python精简笔记

python精简笔记-字符串基本用法 字符串常见用法: * encode() # 编码成bytes类型 * find() # 查找子串 * index() # 获取下标 * replace() # 替换子串 * len(string) # 返回字符串长度,...

平头哥-Enjoystudy
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部