阅读更多

13顶
1踩

编程语言

原创新闻 Node.js的颠覆者:PHP的Swoole扩展

2013-08-02 15:31 by 正式记者 matyhtf 评论(20) 有37172人浏览

最近2年Node.js很火,异步与协程是网络开发方面热门的话题。在追求新技术的同时,也应该反思下这里面存在的陷阱。Node.js确实是一门有趣好玩有个性的语言和技术,动态性,全异步回调的方式,闭包等等特性。值得所有程序员尝试一下。

 

但本文将介绍的是一门另外的容易被大家轻视的编程语言:PHP。长期以来PHP都是作为一门为Web开发而生的前端脚本语言。PHP极其的简单,你可以在一周只能掌握它,一月内开发出一个功能丰富的网站。发展至今PHP其实已经完全不再是一门简单的语言了,PHP的功能保罗万象,常用的操作系统功能,如进程管理,信号,网络通信,多线程,ptrace、inotify、加密解密、压缩都有相应的扩展实现,而且PHP可以很好的与C/C++互相调用。PHP提供了ZendAPI,可以很方便地使用C来扩充PHP的功能。语言特性方面PHP5.4提供的namespace,phar打包,composer依赖管理,Trait,完整的面向对象编程语法,强大的魔术方法和常量,字符串与函数类对象直接转换,闭包和匿名函数等丰富的语言特性。在后端开发方面强大到堪比Java,C#,但开发效率更高。

 

PHP对比Node.js的优势

1、PHP开发效率更高

PHP比Node.js更简单直接,这一点有点像C了。使用PHP开发一个功能,几乎是所有语言中效率最高的,没有之一。

2、PHP程序员更多

PHP因为比较容易入门的原因,程序员数量远超其他语言。其他语言程序员也有很大一部分会PHP。

 

3、PHP开源项目多

PHP有大量开源的项目,有各种第三方库

 

Node.js最大的特色之一是内置了异步高性能的Socket Server/Client实现,在此基础上提供了内置的Web服务器。PHP里也有类似的神器,那就是Swoole扩展。使用Swoole扩展完全可以开发出一个高性能安全稳定的服务器程序来。丝毫不逊于Node.js,而且在某些方面比Node.js更强大。

 

Swoole使用C语言编写,以PHP扩展的方式来运行。Swoole的网络IO部分基于epoll/kqueue事件循环,是全异步非阻塞的。业务逻辑部分使用多进程同步阻塞方式来运行。这样既保证了Server能够应对高并发和大量TCP连接。又保证业务代码仍然可以简单的编写。

 

Swoole对比Node.js的优势

1、swoole是原生支持多进程/多线程的

开发者只需要修改一个参数,配置下要启动多少个进程即可。而Node.js的网络库本身并没有提供多进程/多线程的实现。开发者需要自行创建进程。或者干脆使用单线程。这样无法充分利用多核。

 

2、swoole使用消息传递+多Worker进程,而不是多线程+共享内存+加锁

,共享内存的性能虽然很好,但存在安全问题,需要读写时加锁。锁的粒度过大会导致只有一个线程在运行。锁太复杂又会有死锁问题。所以开发者需要非常谨慎小心。

传统的

 

3、swoole的代码编写是同步,而不是嵌套异步回调

Node.js的代码如果太复杂,会嵌套多层回调,使代码丧失可读性,程序流程变得很乱。Swoole使用了传统Linux下半同步半异步多Worker的实现方式。业务代码按照同步方式编写,更简单。

Swoole也内置了Socket客户端的实现,但采用的是同步+并行方式来执行。PHP本身也提供了socket的功能,但某几个函数存在一些bug,而且比较复杂。Swoole内置的客户端类更加安全和简化。

 

4、swoole内置了Node.js所没有的额外特性

如CPU Affinity设置,守护进程化,混合UDP/TCP多端口监听,多定时器等。

 

有无成功的案例?

国内某大公司知名SNS网站,全球排名200。内部已经使用此方式来开发了。有600多台PHP语言开发的WebServer,200多台PHP开发的SOA服务器。300多台异步事务服务器。

 

Swoole项目地址:

https://github.com/matyhtf/swoole

13
1
评论 共 20 条 请登录后发表评论
20 楼 qq996150938 2015-11-15 21:31
你吹大了,本文写的毫无中心,毫无说服力,欠骂的文档。写作水平底下。

全篇没有什么 技术分析 ,却直接就把nodejs鄙视了。

作为 phper 我也是笑了!
19 楼 opaquefog 2014-12-24 15:38
7454103 写道
javaer  微笑路过!

Java好吗?
我印象中的java web应用笨拙、开发效率低下、资源占用多
非web应用又比不过原生代码
除了vm能在跨平台方面有点想象力,你的应用在多个平台上迁移过么?
运算密集型不是php强项,io密集型 瓶颈就不在语言而在架构

我可以负责任地说国内java ee应用没几个速度快的,都死慢死慢
为啥,大量不懂基本原理的java毕业生涌入人才市场 代码烂到你看了都想吐
18 楼 aa2071518 2014-05-26 15:00
matyhtf 写道
可以不释放资源的,cli下。
cuippan 写道
哈哈
wsyb 写道
kidneyball 写道
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?

现在还是。




应该是fastcgi模式吧
17 楼 月影无痕 2014-01-09 10:45
stone_feng 写道
node.js本身可以使用cluster利用多核。。。。这篇文章的小编水平确实有限。


任何程序,使用cluster都可以利用多核
16 楼 闫老三 2013-08-08 12:28
我也微笑路过
15 楼 shenzhe 2013-08-05 11:23
fjjiaboming 写道
哪个2货 推销PHP  吹到天了.


你有看过swoole的代码否?你有真正了解swoole的运行机制么?

没有调查就没有发言权,喷也要喷的的技术含量先。
14 楼 yearnfar 2013-08-05 11:01
fengyuan1314 写道
"几乎是所有语言中效率最高的,没有之一"
哈哈 笑死人了~~~~

是开发效率,当然也要因人而异,因水平而异
13 楼 yearnfar 2013-08-05 10:56
PHPer顶一个
12 楼 matyhtf 2013-08-05 10:21
没有说node.js不可以利用多核,但是需要开发者额外来写代码。swoole的使用完全不需要开发这来管理进程的创建与回收,这些swoole内核已经帮你做好了。

stone_feng 写道
node.js本身可以使用cluster利用多核。。。。这篇文章的小编水平确实有限。

11 楼 stone_feng 2013-08-05 09:47
node.js本身可以使用cluster利用多核。。。。这篇文章的小编水平确实有限。
10 楼 matyhtf 2013-08-05 09:32
可以不释放资源的,cli下。
cuippan 写道
哈哈
wsyb 写道
kidneyball 写道
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?

现在还是。


9 楼 fengyuan1314 2013-08-05 09:31
"几乎是所有语言中效率最高的,没有之一"
哈哈 笑死人了~~~~
8 楼 matyhtf 2013-08-05 09:30
fastcgi或者mod_php还是这样的。
但使用Swoole开发的Server可以使用连接池。

kidneyball 写道
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?

7 楼 cuippan 2013-08-03 12:38
哈哈
wsyb 写道
kidneyball 写道
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?

现在还是。

6 楼 wsyb 2013-08-03 12:03
kidneyball 写道
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?

现在还是。
5 楼 Pontifex 2013-08-03 11:19
7454103 写道
javaer  微笑路过!

cer 微笑不语
4 楼 fjjiaboming 2013-08-03 09:09
哪个2货 推销PHP  吹到天了.
3 楼 kidneyball 2013-08-02 20:25
好久没接触PHP,借地方问下,现在PHP还是每个请求进来都重新初始化资源,请求执行完毕后全部丢弃吗?
2 楼 jjcang 2013-08-02 18:50
读过swoole的代码,结构很不错。
1 楼 7454103 2013-08-02 17:53
javaer  微笑路过!

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • Node.js的颠覆者:PHP的Swoole扩展 (转载)

    最近2年Node.js很火,异步与协程是网络开发方面热门的话题。在追求新技术的同时,也应该反思下这里面存在的陷阱。Node.js确实是一门有趣好玩有个性的语言和技术,动态性,全异步回调的方式,闭包等等特性。值得所有...

  • Node.js 新特性将颠覆 AI、物联网等更多惊人领域

    点击蓝字 「前端小苑」关注我新版 Node.js 的特性并非这个平台此前的那些等闲卖点。Node.js 主要以其迅速和简洁而闻名。这也是为何那么多公司都愿意尝试 Node.js。然而,随...

  • [译] Node.js 新特性将颠覆 AI、物联网等更多惊人领域

    原文地址:New Node.js 12 features will see it disrupt AI, IoT and more surprising areas 原文作者:Adam Polak 译文出自:掘金翻译计划 ...译者:Badd ...Node.js 新特性将颠覆 AI、物联网等更多...

  • Swoole:重新定义PHP

    PHP语言的高性能网络通信框架,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。 Swoole可以广泛应用于互联网、...

  • 给各位PHP程序员十点未来的建议

    PHP 从诞生到现在已经有20多年历史,从Web时代兴起到移动互联网退潮,互联网领域各种编程语言和技术层出不穷, Node.js 、 GO 、 Python 不断地在挑战 PHP 的地位。这些技术的推动者非常热衷于唱衰 PHP , PHP 语言...

  • 2019年PHP程序员未来路在何方

    PHP 从诞生到现在已经有20多年历史,从Web时代兴起到移动互联网退潮,互联网领域各种编程语言和技术层出不穷, Node.js 、 GO 、 Python 不断地在挑战 PHP 的地位。这些技术的推动者非常热衷于唱衰 PHP , PHP 语言...

  • 除了学习PHP,还应该学什么?

    Node.js 的异步回调 Swoole 有,Go语言的协程 Swoole 也有,这完全颠覆了对 PHP 的认知。 使用 Swoole PHP 可以实现常驻内存的 Server 程序,可以实现 TCP 、 UDP 异步网络通信的编程开发。 过去PHP只能做一个 Web ...

  • 除了学习php,你还应该学什么?

    PHP 语言之所以能有今天的地位,得益于PHP语言设计者一直遵从实用主义,将技术的复杂性隐藏在底层。PHP 语言入门简单,容易掌握,程序健壮性好,不容易出现像 Java 、 C++ 等其他语言那样复杂的问题,如内存泄漏和 ...

  • PHP 是最好的语言?关于 PHP 开发未来的 6 点建议

    抛开玩笑梗,认真来说,PHP 的确称得上最好的语言之一。首先,PHP 入门简单,容易掌握,对新手友好,而且程序...PHP 官方提供的标准库非常强大,各种功能函数包括MySQL、Memcache、Redis、GD图形库、CURL、XML、JS...

  • 好文分享-php学习之路

    PHP 从诞生到现在已经有 20 多年历史,从 Web 时代兴起到移动互联网退潮,互联网领域各种编程语言和技术层出不穷, Node.js 、 GO 、 Python 不断地在挑战 PHP 的地位。这些技术的推动者非常热衷于唱衰 PHP , PHP ...

  • 初识swoole

    Node.js 的异步回调 Swoole 有,Go语言的协程 Swoole 也有,这完全颠覆了对 PHP 的认知。使用 Swoole PHP 可以实现常驻内存的 Server 程序,可以实现 TCP 、 UDP 异步网络通信的编程开发。过去PHP只能做一个 Web ...

  • 前锋php人工智能_人工智能除了学习php,还应该学什么?

    Composer第一点就要提 Composer ,自从 Composer 出现后,PHP 的依赖管理可以变得非常简单。程序内依赖一些类库和框架,直接使用 Composer 引入即可,通过使用 composer update 安装依赖的包。解决了过去加载外部库...

  • .NET5仓储管理系统:集成EFCore、Redis缓存、RabbitMQ等技术实现企业级应用

    内容概要:本文详细介绍了基于.NET5开发的一个仓储管理系统,涵盖了多个关键技术的应用。首先,在数据访问方面,使用了EF Core进行ORM操作,并引入了全局逻辑删除和多租户过滤等功能。其次,权限管理部分采用Policy机制实现动态按钮权限控制,权限数据存储于Redis中,确保高效响应。再次,消息队列方面,通过RabbitMQ实现库存变动后的异步通知,保障库存数据的一致性和可靠性。此外,系统还支持多租户模式,能够根据不同租户的需求灵活切换数据库连接。前端则选择了LayUI作为主要框架,配合WebSocket实现库存变化的实时推送。部署环节涉及Ocelot网关、Consul服务注册以及Docker容器化部署,确保系统的高可用性和扩展性。 适合人群:具有一定.NET开发经验的研发人员和技术爱好者。 使用场景及目标:适用于希望深入了解.NET5企业级应用开发的技术人员,尤其是对仓储管理系统感兴趣的人群。通过学习本文,读者可以掌握如何将多种现代技术集成到一个完整的解决方案中,从而提高开发效率和系统性能。 其他说明:文中提供了大量实际代码片段,帮助读者更好地理解和实践相关技术。同时,作者分享了许

  • 中国联通自智网络技术白皮书-云光和云网专线场景的技术特征与应用

    内容概要:本文档是中国联通发布的关于自智网络技术白皮书,详细介绍了云光和云网专线场景下的自智网络技术。主要内容涵盖行业洞察、中国联通专线自智网络概述、云光和云网专线自智网络的技术特征、分级标准及其关键技术,以及专线自智网络的分级测评和认证体系。文中强调了自智网络在提升网络智能化、自动化方面的关键作用,特别是在云光和云网专线场景的应用,旨在为行业客户提供高品质的专线服务,促进网络向融合化、智能化、绿色化发展。 适合人群:适用于通信行业的技术人员、研究人员、管理人员,尤其是关注自智网络技术及其应用的专业人士。 使用场景及目标:①帮助行业客户理解自智网络技术在云光和云网专线场景中的应用;②为运营商提供技术参考,提升网络智能化水平;③促进产业链上下游协同发展,推动自智网络的商业化应用。 其他说明:本文档不仅提供了详细的理论和技术解析,还结合了中国联通的实际案例,展示了自智网络在实际应用中的成效和发展前景。

  • 三菱Q系列PLC在液晶电视导光板加工中的应用:QD75MH总线伺服与自动化控制系统详解

    内容概要:本文详细介绍了三菱Q系列PLC在液晶电视导光板加工中的应用案例。主要内容涵盖Q系列PLC的使用、QD75MH定位模块和SSNET总线伺服的应用、伺服控制、触摸屏程序设计以及温控器的使用。文中不仅提供了详细的硬件配置和软件编程实例,还深入解析了各个组件的工作原理及其协同工作的机制。此外,文章还分享了一些实际操作中的经验和常见问题解决方案,如伺服控制中的加减速曲线优化、温控器的Modbus通讯调试、以及总线通讯中的丢包问题处理等。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对三菱Q系列PLC和伺服控制系统感兴趣的读者。 使用场景及目标:适用于液晶电视导光板加工生产线的设计、安装、调试和维护。目标是帮助技术人员理解和掌握三菱Q系列PLC及相关组件的应用,提升系统的稳定性和精度。 其他说明:文章通过具体的代码示例和实际操作经验,展示了如何利用三菱Q系列PLC实现高效、稳定的工业自动化控制。对于希望深入了解工业自动化控制技术和三菱PLC编程的读者来说,是一份非常有价值的参考资料。

  • (源码)基于Go语言的用户积分系统 PointSystem.zip

    # 基于Go语言的用户积分系统 PointSystem ## 项目简介 本项目是一个基于Go语言的用户积分系统,旨在实现常见的用户积分功能,包括积分的获取、扣除和查询等。该系统适用于各种需要用户积分的场景,如购物网站、社区论坛等。 ## 项目的主要特性和功能 1. 用户积分管理系统能够记录用户的积分变化,包括增加积分和减少积分。 2. 积分查询用户可以查询自己的总积分。 3. 积分明细查询用户可以查询自己的积分变化明细,包括积分增加和扣除的记录。 4. 日志记录系统能够记录操作日志,方便问题追踪和审计。 ## 安装使用步骤 1. 确保已安装Go语言环境,并设置好环境变量。 2. 下载项目的源代码文件,解压到本地目录。 3. 在项目根目录下,找到并打开文件 confconf.go,根据实际需求修改数据库连接配置信息(mysqlHost、mysqlUsername、mysqlPassword、mysqlDb 和 LogPath)。

  • (源码)基于Arduino的SIMONTRONI游戏.zip

    # 基于Arduino的SIMONTRONI游戏 ## 项目简介 SIMONTRONI是一个基于Arduino的交互式记忆游戏。玩家需要记住并重复由LED灯显示的随机序列。随着游戏的进行,序列的长度会逐渐增加,挑战玩家的记忆能力。该项目还包括一个音量调节功能,通过旋钮调节游戏音量。 ## 项目的主要特性和功能 1. 记忆挑战玩家需要记住并重复LED灯显示的序列。 2. 多级游戏随着游戏的进行,序列的长度会逐渐增加,增加游戏的难度。 3. 音量调节通过旋钮调节游戏音量,满足不同玩家的需求。 4. 硬件交互使用Arduino Uno、LED灯、按钮和电阻等硬件组件,实现游戏的物理交互。 ## 安装使用步骤 1. 准备硬件 1个Arduino Uno 4个LED灯 4个按钮 1个蜂鸣器 1个5k电位器 若干电阻(220和330) 1个面包板和若干导线 2. 下载代码

  • sqlite-devel-3.26.0-15.el8.x64-86.rpm.tar.gz

    1、文件说明: Centos8操作系统sqlite-devel-3.26.0-15.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf sqlite-devel-3.26.0-15.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm

  • (源码)基于Python的迷宫探索强化学习项目.zip

    # 基于Python的迷宫探索强化学习项目 ## 项目简介 本项目是一个基于强化学习算法的迷宫探索任务。它使用Python编程语言和多种强化学习算法(如QLearning、Sarsa、Sarsa Lambda等)来训练智能体,使其在随机变化的迷宫环境中找到最短路径到达目标点。 ## 项目的主要特性和功能 1. 迷宫环境模拟项目使用CSV文件定义迷宫地图,模拟二维迷宫环境,包括障碍物、悬崖和终点等。 2. 强化学习算法实现实现了QLearning、Sarsa、Sarsa Lambda等强化学习算法,用于智能体的决策过程。 3. 奖励函数设计设计了多种奖励函数,包括距离奖励、危险区域惩罚、防止终点区域“守株待兔”现象和重复路径惩罚等,以引导智能体更好地探索迷宫。 4. 经验回放策略采用了经验回放策略,以提高数据利用效率并稳定学习过程。 5. 可视化界面提供了基于pygame库的可视化界面,用于展示迷宫的布局、智能体的移动和奖励曲线等。

Global site tag (gtag.js) - Google Analytics