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

[经验分享] PHP的异步并行网络扩展swoole

[复制链接]

尚未签到

发表于 2018-12-16 07:59:51 | 显示全部楼层 |阅读模式
  Swoole是PHP的异步并行扩展,有点像Node.js,但swoole既支持同步又支持异步,比node更强大。Swoole扩展是基于epoll高性能事件轮询,并且是多线程的,性能非常好。
  Swoole除了提供网络Server/Client的功能之外,还提供了Task异步任务管理器,可以使你的程序中某些处理慢的函数异步去执行。
  本文说下如何使用swoole扩展。
第一步 安装
  swoole仅支持Linux/FreeBSD/Mac,如果你使用的是Windows系统,请安装一个虚拟机,VirtualBox/VMWare都可以。然后在虚拟机里安装Linux。
  swoole已经加入到PHP的官方扩展库中,所以在Linux系统里只需要执行
  Shell代码  

  •   pecl install swoole
  即可安装。安装完后修改php.ini,加入extension=swoole.so。然后查看php -m 或者 phpinfo,如果出现swoole证明安装成功了。
第二步 编写Server程序
  创建一个PHP脚本文件server.php,代码内容:
  Php代码  

  •   $serv = new swoole_server("127.0.0.1", 9501);
  •   $serv->on('connect', function ($serv, $fd){
  •   echo "Client:Connect.\n";
  •   });
  •   $serv->on('receive', function ($serv, $fd, $from_id, $data) {
  •   $serv->send($fd, 'Swoole: '.$data);
  •   });
  •   $serv->on('close', function ($serv, $fd) {
  •   echo "Client: Close.\n";
  •   });
  •   $serv->start();
  然后执行:
  Java代码  

  •   php server.php
  使用telnet连接到你的服务器:
  Java代码  

  •   telnet 127.0.0.1 9501
  •   > hello world
  •   > Swoole: hello world
  是不是非常简单,仅仅11行代码就创建了一个异步高并发的TCPServer,通过底层的网络来进行数据收发。接下来就是你就可以做你想要做的事情了,即时聊天,文件收发,通信等等。
Swoole-Task:简单高效的异步任务处理框架
Swoole-Task
  github 地址:https://github.com/luxixing/swoole-task
  欢迎 star 提 issues
Swoole-Task 用法示例

  •   路由说明
  127.0.0.1:9510/ctrl/action?paramas=xxx
  ctrl对应app/ctrl目录下的xxxCtrl.php文件(xxxCtrl.php中的class名称也必须是xxxCtrl,继承base\Ctrl)
  action对应xxxCtrl.php文件中的xxxAction(action 的最后必须返回$this->ret,即最后一句 return $this->ret)
  127.0.0.1:9510?op=ctrl.action&params=xxx 等同于 127.0.0.1:9510/ctrl/action?paramas=xxx

  •   启动swoole-task后发起请求(假定监控的ip和端口是127.0.0.1:9510)
  curl "127.0.0.1:9510/ctrl/action?paramas=xxx" 或者 curl "127.0.0.1:9510?op=ctrl.action&params=xxx"
  投递任务到swoole-task进行处理

  •   swoole-task目录结构说明
  app  swoole-task具体处理业务逻辑的地方
  app\config 配置文件目录,根据环境dev,test,prod来加载配置,环境的配置在config/swoole.ini的配置项 env
  app\ctrl controller文件所在目录,处理具体业务逻辑,继承base\Ctrl这个类
  app\dao  数据访问层,操作数据库的方法
  app\helper 公共方法类
  app\vendor 如果依赖composer 第三方库,在在app目录下创建composer.json
  base 核心框架类,Ctrl Dao Helper App 四个类,命名空间base
  config swoole-task 配置文件目录swoole.ini,配置参数类容参考源码说明
  tmp 临时目录,日志swoole-task中间文件等等在此目录下存放
  swoole-task 本身是一个比较简单的基于swoole扩展的异步任务处理框架,更详细使用方法看源码,或者在github留issues,有好的建议我会根据情况及时改进
Swoole-Task服务管理脚本功能说明
  1 如果swoole.php 脚本所在目录config/swoole.ini 文件不存在,可以直接删除config目录,会自动创建配置文件,创建后的文件根据需求修改
  2 注意swoole.ini 的参数dev,这个取值为dev,test,prod 根据此值读取swoole/app的配置文件
用法介绍

  •   服务启动
#启动服务,不指定绑定端口和ip,则使用config目录下的swoole.ini配置  
php swoole.php start #启动服务 指定ip 和 port
  
php swoole.php -h127.0.0.1 -p9510 start#启动服务 守护进程模式
  
php swoole.php -h127.0.0.1 -p9510 -d start#启动服务 非守护进程模式
  
php swoole.php -h127.0.0.1 -p9510 -D start#启动服务 指定进程名称(显示进程名为 swooleServ-9510-[master|manager|event|task]
  
php swoole.php -h 127.0.0.1 -p 9510 -n 9510 start

  •   服务停止(停止服务最少要指定端口)
php swoole.php -p 9510 stopphp swoole.php -h 127.0.0.1 - p 9510 stop

  •   服务重启(至少指定端口)
php swoole.php -p 9510 restart  
php swoole.php -h 127.0.0.1 - p 9510 restart

  •   服务状态(必须指定ip 和 端口)
php swoole.php -h 127.0.0.1 - p 9510 status

  •   swoole-task所有启动实例进程列表(一台服务器swoole-task可以有多个端口绑定的实例)
php swoole.php list参数说明

  •   --help
      显示帮助
  •   -d, --daemon
      指定此参数,服务以守护进程模式运行,不指定读取配置文件值
  •   -D, --nondaemon
      指定此参数,以非守护进程模式运行,不指定则读取配置文件值
  •   -h, --host
      指定监听ip,例如 php swoole.php -h 127.0.0.1
  •   -p, --port
      指定监听端口port, 例如 php swoole.php -h 127.0.0.1 -p 9520
  •   -n, --name
      指定服务进程名称,例如 php swoole.php -n test start, 则进程名称为SWOOLE_TASK_NAME_PRE-name
命令说明

  •   start 启动服务
  可指定服务绑定ip 端口 及 是否守护进程模式,还有启动后进程名称(进程名称前缀默认为swooleServ-, 指定后 swooleServ-name-[master|manager|event|task])

  •   stop  停止服务
  必须指定端口参数 -p(--port)

  •   restart 重启服务
  必须指定端口参数 -p(--port) 后续是否需要根据进程名称重启根据实际情况来看(--TODO)

  •   status
  查看指定ip和端口的服务状态,tasking_num是指当前正在运行的任务

  •   list
  查看当前服务器上运行的swoole-task实例,
  返回结果显示服务进程的 USER PID RSS(kb)[使用内存] STAT[进程状态] START[进程运行开始时间] COMMAND[进程命令或者进程名称]



运维网声明 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-651846-1-1.html 上篇帖子: 升级php 下篇帖子: php5.3 fpm centos6
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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