polarphp:一个新的 PHP 语言运行时环境

2019-11-19 21:14:36 951 思小齐 思小齐

图片描述

polarphp 项目介绍

polarphp是一个全新的PHP语言的运行时环境,基于目前最新的zend virtual machine进行打造,支持最新的语言规范,同时提供了自己的运行时标准库 (libpdk)。

简单来说polarphp之于PHP语言的关系跟NodeJS之于Javascript语言一样,NodeJSv8引擎基础之上进行打造,为Javascript提供了一个在服务端运行的环境。同样polarphp也在zend engine的基础上进行打造,实现了一个除Web开发之外的一个全新的运行环境。

为什么发起 polarphp 项目

随着GoNodeJS的强势崛起,PHP的市场份额逐渐被蚕食,而PHP官方仍然坚守在Web编程领域,有些东西越是想守住就越守不住。polarphp借鉴NodeJSGo的相关特性对zendVM重新封装,去掉PHP一些古老弃用的特性和强Web属性,通过实现一套新的运行时框架libpdk,将PHP语言打造成为一门真正的通用性脚本语言,赋能PHP,让其拥有异步编程,协程,线程,内置的unicode支持,标准的文件IO等等特性,让PHP程序员不仅仅能做web应用,也能从容面对真正的服务端应用。

polarphp 提供的基础设施

  1. 直接面向终端,去掉SAPI从而更好的实现服务端环境。
  2. 规范化OPCODE形成规范,从而提供一种类似pyc文件的预编译机制。
  3. 提供原生多线程支持,借鉴Java在多线程方面的编程范式。
  4. 提供原生异步IO支持。
  5. 提供针对字符串的unicode支持。
  6. 提供一种全新的包组织方式,内置包依赖管理工具,类似Cargonpm
  7. 提供内置的API文档生成工具。

polarphp 大致架构

项目主要由三部分构成,主要有如下三个子模块

  1. polarvm
  2. zendAPI
  3. libpdk

这个模块大致的关系如下:

polarvm <=> zendAPI <=> libpdk

polarvm 介绍

现阶段实现对zend engine的封装,实现最基本的PHP执行环境,比如实现:

  1. 语言解析,OPCODE的执行。
  2. 实现基础运行环境,实现变量操作,数组操作,类加载机制,语言反射等等。
  3. zend engine的初始化,实现语言引擎与终端的链接,实现语言引擎对标准输入输出的直接控制。
  4. 实现语言引擎与标准库之间的回调机制。

zendAPI 介绍

做过PHP扩展的朋友应该知道,在我们开发扩展的时候,zend engine的很多接口都是通过宏调用的方式提供的,类型不安全,出错了不好调试,而且有些宏还长的特别像,同时操作数组的时候特别繁琐。zend enginegc是通过引用计数实现的,同时C语言又没有什么从语言层面帮我们管理计数的机制,从而我们在写扩展的时候管理内存不仅很繁琐而且一不小心就会造成内存泄露。特别是将写时复制和PHP变量之间的引用一起使用的时候,非常让能头痛。

如果我们的标准库如果直接基于原生的zend engine的接口,势必扩展性,可维护性会受到严重影响,特别是目前polarvm是基于zend engine二次开发的可观情况下。所以在语言引擎和标准库之间实现一个屏蔽层,对下实现对zend engine原生接口的封装,对上提供一套相对稳定且简单的面向对象的CPP编程接口。

zendAPI 提供如下的特性:

  1. 完全面向对象,对Zend Engine API进行二次定义
  2. 使用现代的C++11语法进行开发,便于维护
  3. 最大化屏蔽PHP版本对扩展开发的影响,zendAPI将对Zend Engine API不同版本带来的差异屏蔽掉
  4. 高覆盖的单元测试,保证代码质量
  5. 在封装的时候,尽最大能力保证性能
  6. 致力于项目库的二进制兼容

libpdk 介绍

libpdk 的定位是polarphp语言环境中的标准库,PDKPHP Development Kit几个单词的缩写。在设计上参考JavaJDK的模块组织风格,为PHP提供一套严谨并且功能强大的运行时标准库,让实现服务端高效编程成为可能,比如使用PHP实现类似Netty那样的事件驱动的网络框架,或者CoreDNS那样的应用项目成为可能。同时也可以让开发终端程序比如npmCargoPM2等等类似的程序更加便捷。在Web领域,libpdkpolarphp能够脱离SAPI直接像go那样自己对端口进行监听,从而实现gin那样的轻量级的服务框架更加方便,底层基于事件循环模型和多线程模型。

项目库地址: https://github.com/polarphp/l...

PDK计划了如下几个模块

  • Base module (基础模块,实现最基本的功能,比如输入输出,文件系统,进程与线程,事件模型等等)
  • Network module(网络模块,在基础模块之上,实现一套高性能的网络框架,让编写服务端系统更加便捷)
  • Web module (Web模块,实现常见的Http协议,提供一个类型SerletWeb运行时容器)
  • GUI module (用户界面模块,未来实现,让PHP具备编写常见的客户端系统,基于openGL实现)

polarphp 的开发计划

因为开发资源有限,开发计划暂定如下:

  1. 使用cmakezend VM进行编译,生成polarphp定制版的PHP语言虚拟机。
  2. 语言支持项目,语言测试框架,移植LLVM项目的lit测试框架。
  3. 实现polarphp驱动程序,实现从命令行执行PHP代码。
  4. polarphp虚拟机进行回归测试,暂定跑通PHP的语言虚拟机相关回归测试。
  5. 实现polarphp的内置函数。
  6. 发布核心虚拟机的docker镜像。
  7. 整合libpdk运行时框架。
  8. 实现人性化安装,尽量以最少的步骤进行polarphp的安装。
  9. 实现包管理器。
  10. 实现语言配套小工具,比如文档生成工具等等。

polarphp 优先支持的操作系统

  • debain
  • centos
  • ubuntu
  • openSUSE
  • macOS

未来打算原生支持Windows操作系统,目前正在进行知识储备。

polarphp 目前的现状

目前项目处于一个非常前期的阶段,通过docker镜像来实现项目的迭代发布,目前主要是我一个人在业余时间进行开发,欢迎大家一起玩。2019年一个重要的任务就是完善polarphp标准库libpdk,以及实现在主流的Linux操作系统上稳定的运行。

如何参与

目前我们暂时只针对中国的用户,所以采用了微信群的交流方式:
微信号:zzu_xiuxiu

目前有以下工作组

  1. 语言核心团队
  2. 标准库团队
  3. 生态链项目团队
  4. 文档团队
  5. 官方网站维护团队