Swoole系列(一):简介

前言:
  实际上作为一名PHP程序员,我很清楚PHP的确有很多局限性,比如Unix系统编程、网络通信编程、异步io,大部分PHPer不懂。PHP界也确实没有这样的东西。Swoole开源项目就是为了弥补PHP在这些方面的缺陷诞生的。与WordPress这些产品不同,swoole实际上是一个网络通信和异步io的引擎,一个基础库。PHPer可以基于swoole去实现过去PHP无法实现的功能。swoole为PHPer打开了通往另一个世界的大门。

 

我们为什么用Swoole:

  用户打开了我们的网站。他要做的就是勾选需要发邮件的代理商列表,然后把结算邮件发出去。假如我们需要发1封邮件,我们写个函数执行即可。考虑到网络可能会稍微有点延迟,但是是可以接受的,用户会乖乖等你的网页发完邮件了再关闭网页。假如我们要发布10封邮件,用一个for循环,循环10遍执行发邮件操作。这时候,也许10倍的网络延迟会让用户稍微有点不耐烦,但勉强可以等吧。假如要发100封邮件,for循环100遍,用户直接揭竿而起,什么破网站!

  但实际上,我们很可能有超过1万的邮件。怎么处理这个延迟的问题?
  答案就是用异步。把“发邮件”这个操作封装,然后后台异步地执行1万遍。这样的话,用户提交网页后,他所等待的时间只是“把发邮件任务请求推送进队列里”的时间。而我们的后台服务将在用户看不见的地方跑。而swoole就为我们实现了异步队列处理及并发等问题。而我之前参与的一个项目经常需要将更新数据到elasticsearch索引引擎中,所以就利用swoole的队列处理功能以及它的计划任务的功能。

 

Swoole应用案例:

  战旗TV,虎牙直播,YY语音等等。。。

  它们的共同特点,高并发,大流量。

 

Swoole能做什么?

  •   异步多线程服务器及客户端
  •   异步mysql、redis、任务队列
  •   http/websocket服务器/客户端
  •   异步文件读写
  •   协程(本来是go语言专有的东西,现在php也可以用了)

 

 

简单总结Swoole:

 

  异步、并行、高性能

 

  纯C编写

 

  Php扩展

 

posted @ 2017-11-15 21:26  shifu204  阅读(498)  评论(0编辑  收藏  举报