利用swoole+redis实现股票和区块链服务
2017-09-10 15:39
489 查看
本文主要给大家介绍了关于swoole+redis实现股票和区块链服务的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
PHP 的redis扩展是阻塞式 IO ,使用订阅/发布模式时,会导致整个进程进入阻塞。因此必须使用Swoole\Redis异步客户端来实现。
$server = new swoole_websocket_server("0.0.0.0", 9501); $server->on('workerStart', function ($server, $workerId) { $client = new swoole_redis; $client->on('message', function (swoole_redis $client, $result) use ($server) { if ($result[0] == 'message') { foreach($server->connections as $fd) { $server->push($fd, $result[1]); } } }); $client->connect('127.0.0.1', 6379, function (swoole_redis $client, $result) { $client->subscribe('kline1min'); }); }); $server->on('open', function ($server, $request) { }); $server->on('message', function (swoole_websocket_server $server, $frame) { $server->push($frame->fd, "hello"); }); $server->on('close', function ($serv, $fd) { }); $server->start();
- 在进程启动(onWorkerStart)时创建了Swoole\Redis客户端,连接到Redis服务器
- 连接成功后,订阅msg_0主题的消息
- 当有新的message时,Swoole\Redis会触发onMessage事件回调
- 在这个回调函数中使用$server->connections遍历服务器所有的连接,发送消息
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- IFC标准是为了满足建筑行业的信息交互与共享而产生的统一数据标准,是建 筑行业事实上的数据交换与共享标准。本文概要介绍了IFC标准的产生及发展 历程,IFC的整体框架结构,简要说明了IFC标准的实现方法和过程,描述了 当前的应用以及我们应该更加积极地利用IFC标准为建筑软件行业服务。
- 利用google的短网址服务去实现简化网址
- 利用redis-sentinel+consul实现redis高可用
- 利用redis和php-resque实现后台任务
- 利用Java技术实现基于XML的Web服务
- 利用Redis实现分布式锁
- Redis缓存服务搭建及实现数据读写
- 利用Nginx负载均衡的访问SpringBoot服务,还有如何利用Nginx实现404,500等错误页面的拦截
- 虚拟机利用Host-only实现在不插网线的情况下,虚拟机与主机实现双向通信,实现ssh连接以及samba服务实现共享
- 利用多写Redis实现分布式锁原理与实现分析
- .Net网络通讯编程[利用Socket实现字串、文件、序列化对象传输]--使用封装的网络服务4[聊天室]
- C# 基于StackExchange.Redis.dll利用Redis实现分布式Session
- 利用多写Redis实现分布式锁原理与实现分析
- 利用Redis 实现消息队列
- 利用虚拟机Ubuntu的Samba服务,实现Windows映射网络盘到Ubuntu
- kubernetes集群中利用etcd和grpc实现golang服务间通信
- Redis探索之旅(11)- Redis服务之主从架构实现
- 利用Redis 实现消息队列
- 利用tomcat redis 实现session共享
- 利用git和pm2实现快速部署多个服务