easyswoole - 基于swoole扩展实现的一款高性能php框架

初識 Swoole

前言


在之前的教程當中我們已經了解到了php的幾種運行模式:

  • CGI 通用網關接口(Common Gateway Interface)
  • Fast-CGIcgi的升級版本,用 PHP-FPM(FastCGI Process Manager)fast-cgi 進程管理器
  • mod 以模塊的形式集成進 Apache 中,接受 Apache 提供的.php文件,并進行解析。
  • CLI 命令行模式,直接使用 PHP 去執行.php文件時便是此模式。

盡管 CLI 模式可以完成更多有趣和強大的功能,但大多數php程序員很少使用 CLI 模式。

起源

Swoole是Rango在2010年底,因為公司業務需要自己實現一個Tcp Socket Server 實現SMT P協議接收數據,但是在當時PHP在這個領域幾乎是一片空白,所以Rango自己學習,最終完成了需求;隨后便開源了此套系統,希望能幫助其他PHPer解決在這個領域的問題,讓PHP從單純的Web開發擴展到更大的空間。

以下內容來自于Swoole官方文檔

項目起源
Swoole 項目最初的想法是來自于之前所做的一個企業軟件項目。當時大概是2010年底,公司產品有一個需求是用戶可以任意生成一個 email 地址,然后其他用戶可以向這個email發郵件,后臺能實時將郵件內容解析成數據,并主動通知用戶。當時項目使用PHP開發的,在實現這個需求時遇到了難題,PHP只能依賴其他的STMP服務器,通過pop3協議定時查收新郵件來完成,這樣就不是實時的。如果要實現的實時系統必須自己寫一個TCP Socket Server實現SMTP協議接收數據。當時PHP在這個領域幾乎是空白,沒有一套成熟的網絡通信框架。為了實現需求,我從socket學起到TCP/IP、IO復用、libevent、多進程,最后終于實現了這套程序。做完這個項目后我就想把這套程序開源出來,希望能幫助其他PHPer解決在這個領域的難題。如果能有這樣一個框架,那么PHP就能從單純地做一個Web網站延伸到更大的空間。

還有一個重要的原因是PHP程序的性能問題,我最早是學Java出身的,工作后才轉行成為一名PHP程序員。在使用PHP開發程序的過程中,我一直在思考的問題 PHP 和 Java 比最大的優勢是什么?簡單高效, PHP 在請求完成之后會釋放所有資源和內存,無須擔心內存泄漏。代碼的質量無論高低一樣運行的很流暢。但同時這也是 PHP 致命的缺點。一旦請求數量上升,并發很高的時候,快速創建資源,又馬上釋放,使得 PHP 程序運行效率急劇下降。另外一旦項目的功能的越來越復雜,代碼增多后,對于 PHP 也會是災難。這也是 PHP 的框架為什么沒有被 PHP 程序員廣泛接受,而 Java 不存在這個問題。再好的框架也會被這種低效的方式拖累,導致系統變慢。所以想到了使用 PHP 來開發 PHP 的應用服務器,讓 PHP 的代碼加載到內存后,擁有更長的生命周期,這樣建立的數據庫連接和其他大的對象,不被釋放。每次請求只需要處理很少的代碼,而這些代碼只在第一次運行時,被 PHP 解析器編譯,駐留內存。另外,之前 PHP 不能實現的,對象持久化、數據庫連接池,緩存連接池都可以實現。系統的運行效率會大大提高。

經過一段時間研究,目前已經初步得到實現。使用 PHP 本身編寫出 HTTP 服務器,以獨立服務器方式運行,單個程序頁面 ( 有對象生成,數據庫連接、 smarty 模板操作 ) 的執行時間由原來的 0.0x 秒,下降到 0.00x 秒。使用 Apache AB 并發 100 測試。比傳統 LAMP 方式, Request per Second 高出至少 10 倍。在我的測試機上 (Ubuntu10.04 Inter Core E5300 + 2G 內存 ) , Apache 只跑到 83RPS 。 Swoole Server 可以跑到 1150 多 RPS。

這個項目就是Swoole的雛形。這個版本一直持續維護了2年多,在這個過程中逐步有了一些經驗積累,對這套技術方案的存在問題有了更深入的理解,比如性能差、限制較多無法直接調用操作系統接口、內存管理效率低下。

入職騰訊
2011年底我入職騰訊,負責朋友網的PHP平臺開發工作。驚奇地發現朋友網的同事不光這樣想了,他們直接做到了。朋友網團隊已經在生產環境中使用了這套方案。朋友網有三架馬車,第一個是PWS,這是一個純PHP編寫的WebServer,朋友網線上有600多臺服務器運行在PWS上,完全沒有使用Apache、PHP-FPM之類的程序。第二個是SAPS,這是使用純PHP開發的一個分布式隊列,當時大概由150臺服務器的集群在跑,很多圖片裁剪、頭像處理、消息同時、數據同步等邏輯全部使用了SAPS做邏輯異步化。第三個是PSF,這是一個PHP實現的Server框架,朋友網很多邏輯層的服務器都是基于PSF實現的。大概有300臺左右的集群在運行PSF服務器程序。在朋友網的這段時間,我學到了很多Linux底層、網絡通信的知識,積累了很多大型集群高并發環境的網絡通信跟蹤、調試經驗,為開發Swoole打下了一個很好的基礎。

開發Swoole
在這期間也學習了解到了Node.js、Golang這些優秀的技術方案,得到了更多靈感。在2012年的時候就有了新的想法,決定使用C語言重新實現一個性能更強、功能更強大的版本。這就是現在的Swoole擴展。

現在Swoole已經被很多PHP技術團隊用于實際項目的開發工作,國內國外都有。國內知名的有百度訂單中心、百度地圖、騰訊QQ公眾號和企業QQ、戰旗直播、360、當當網、窮游等。另外還有很多物聯網、硬件、游戲項目也在使用Swoole 。另外基于Swoole的開源框架也越來越多,比如TSF、Blink、swPromise 等等,在Github上也能找到很多Swoole相關的項目和代碼。

名字由來
Swoole這個名字不是一個英文單詞,是由我創造的一個音近字。我最早想到的名字是叫做 sword-server,寓意是為廣大PHPer創造一把鋒利的劍,后來聯想到 google 也是憑空創造出來的,所以我就給它命名為 swoole。

現在


隨著Swoole進入4.0時代,原2.0時期協程的各種各樣的坑,在4.0都得到了解決。 如今的Swoole可以說是真正好用可靠的PHP異步網絡引擎。

2018年7月Rango辭去工作,組織了全職的研發團隊來開發 Swoole 內核、組件和工具鏈。在文檔、測試、社區運營方面也會投入更多資源。本段來源

Swoole 能做什么


以下內容來源于Swoole官方文檔
Swoole 是使用 CC++ 語言編寫的PHP擴展, 內置了異步非阻塞、多線程的網絡IO服務器,PHP程序員僅需處理事件回調即可,無需關心底層。

同時Swoole也提供了許多非常多的內置功能如:

  • PHP語言的異步多線程服務器
  • 異步TCP/UDP網絡客戶端
  • 異步MySQL
  • 異步Redis
  • 數據庫連接池
  • AsyncTask
  • 消息隊列
  • 毫秒定時器
  • 異步文件讀寫
  • 異步DNS查詢
  • Http/WebSocket服務器端/客戶端
  • Http2.0服務器端/客戶端

與大家熟知的 Workerman 框架不同,Swoole更像是一個基礎庫給了開發者一把無比鋒利的寶劍,可以按照自己想要的方法去使用。

Swoole絕大部分功能都只能運行在 CLI 模式下,也正因為此開發者可以完全的掌控Server的一切,與傳統的 php-fpm 模式不同,Swoole需要開發者自行接管各種相關事件,和管理變量的生命周期等。

與傳統Web開發的區別


我們知道 php-fpmfast-cgi 運行模式的進程管理器,當啟動Server時 php-fpm 會預創建若干個 fast-cgi 處理進程; 每當請求到達 NginxNginx 檢查到請求的是.php文件時,就將請求轉發給 php-fpm Server 然后由 php-fpm 交給某個空閑的進程處理,當處理完成后由 php-fpm 返回給 Nginx 然后由 Nginx 響應給用戶。

傳統PHP開發者幾乎無需關注這其中發生的過程甚至根本不了解,正所謂成也蕭何敗蕭何,一方面雖然降低了開發者入門的門檻但另一方面也使得大量的PHP開發者幾乎不了解也不懂的真正的服務端開發。

SwooleServer 則是相當于取代了 php-fpm 作為管理器的位置, 由于Swoole 是運行在 CLI 模式下, 所以可以常駐運行和以守護進程運行, 但也正因為如此,也需要開發者自行處理變量的銷毀及各種異常和超時的處理。

主站蜘蛛池模板: 木业信息网[www.wood186.com]全国木业建材服务平台 | 上海钧尚电器有限公司 - Faulhaber电机 AMETEK pittman电机 AMETEK ROTRON军用航空风机 Exlar电动缸 MAE电机 MCG电机 CP电动工具 马头工具 AMCI驱动器 直流电机 减速箱 直流伺服电机,无刷电机,直线电机 直流防爆电机 防爆电机 汽车助力转向电机 EPS电机 faulhaber motor faulhaber gearbox NANOTEC电机 ELWOOD电机 PHYTRON电机 EXLAR伺服电动缸 高力矩、高性能直流电机,音圈电机,风机,直流风机,航空风机 | 萘系减水剂|缓凝|早强|聚羧酸|混凝土|石膏板|管桩减水剂厂家-潍坊英宏建材有限公司 | 直膨式空调机组_风冷恒温恒湿_转轮式热回收_屋顶式空调机组_德州瑞尼森环保科技有限公司 | 苏州市相城区望亭镇叶凡工艺服饰绣品厂 | 全球环保研究网_生态环境绿色产业咨询部_生态文明建设行业智库 ? | 南昌运通工程机械租赁有限公司| 轴流风机_混流风机_排烟防火阀-德州辰特空调设备有限公司 | 衡水一体化污水处理设备|循环水旁滤器|加药装置|钢厂浊环净化装置|河北欧意科技集团有限公司 | 呕吐毒素快速检测仪-黄曲霉毒素测定仪-玉米赤霉烯酮快速检测卡-南京微测生物科技有限公司 | 欧美日韩人妻精品一区二区三区_欧美成人精品欧美一级乱黄_亚洲欧美日韩高清一区二区三区_国产一级做a爰片久久毛片_日韩一级视频在线观看播放_精品一区二区三区免费毛片爱_完整观看高清秒播国内外精品资源 | 压缩强度测定仪-纸管平压强度测定仪-电脑拉力仪-杭州纸邦自动化技术有限公司 | 无锡大型数控龙门铣,喷涂加工,回火抛丸加工,精密不锈钢焊接机床身机床底座制造加工-无锡美高帝机械有限公司 | 易居房产律师网|北京房产律师|房产纠纷律师|房产律师 | 专业提供医疗器械,医疗设备,进口国产医疗设备,医疗耗材采购,医疗设备厂家等医疗器械信息-上海聚慕医疗器械有限公司 | 重庆晓宇餐饮文化管理有限公司_重庆晓宇火锅 | 立式离心泵_不锈钢自吸泵_液下泵_变频无负压供水设备-大东海泵业无锡有限公司 | 长春衡宇机械 食品干燥机 微波灭菌机 连续真空干燥机-干燥行业先进企业 | 破碎机锤头-耐磨锤头-合金锤头-河南磐石耐磨材料有限公司 | 数据交易导航,数据资产入表,数据交易平台,数据要素市场 | 制冷设备|冷库|空调|配件【制冷通】国内领先的制冷服务平台 | 金酱酒_金酱酒代理加盟招商_OEM贴牌企业定制! – 金酱酒代理加盟!茅台镇较早的酿酒烧坊,年产优质酱香白酒5000余吨,仁怀市十强白酒企业,主营主品:金酱酒、金酱陈香酒、酱香老酒等系列品牌产品 | 山东岱新起重机械有限公司,单梁桥式起重机,双梁桥式起重机,通用式门式起重机,欧式起重机系列 | 长春网站优化,网络推广,seo快速排名,1.8元/词/天-同信长春网络公司 | 新乡市矿山起重机制造有限公司| 箱包定制_广州箱包厂_双肩电脑背包_双肩旅行包_拉杆箱包_商务公文包_包包批发,深圳爱自由,礼品箱包定制,电话:400-0061-690 | 齐东汽车-提供抑尘车|洒水车|压缩垃圾车|餐厨垃圾车|垃圾转运车|清洗吸污车|扫路车价格,图片及视频 | 气体报警器,有毒气体报警器,可燃气体探测器,乙炔气体报警器,可燃气体检漏仪,便携式气体检测仪,气体报警控制器-山东如特安防设备有限公司 | 金酱酒_金酱酒代理加盟招商_OEM贴牌企业定制! – 金酱酒代理加盟!茅台镇较早的酿酒烧坊,年产优质酱香白酒5000余吨,仁怀市十强白酒企业,主营主品:金酱酒、金酱陈香酒、酱香老酒等系列品牌产品 | 普利卡管|普利卡管接头|普利卡接头-上海闵彬管业有限公司 | 铸铁平台-铸铁平板平台厂家-加工优质高精度检验划线装配T型槽平台-尺寸规格全供应-建新铸造 | 真空清洗炉_真空煅烧炉_铸铝加热器-盐城市钰凯电器有限公司 | 偏光显微镜-金相抛光机|预磨机|磨抛机|镶嵌机|切割机-上海蔡康光学仪器厂 | 文轩热能_水冷板散热器热设计热管理系统_铝型材铲齿摩擦焊热管_散热片散热板生产加工厂家 | 浙江凯力防爆电气集团有限公司【官网】 | 西安木包装箱出口托盘定做价格-抽真空实木包装箱免熏蒸木箱多层板木箱哪家好-模压托盘及白松原木-西安宇森木业 | 深圳市金正电器有限公司| 无塔供水_全自动无塔供水设备_石家庄工泉水处理_无塔供水器 | 微EAM - EHS安全管理系统-设备管理系统-设备全生命周期管理软件-HSE安全管理软件 | 环保除尘设备_燃气/燃油热水锅炉_光氧空气净化器_蒸汽玉米压片机_压片设备_烘干设备-山东金盾节能环保设备有限公司 | 商标注册_商标转让交易_专利申请_版权登记_ISO认证服务咨询-世标知识产权 |