EasySwoole Distributed 基于 Swoole 的 PHP 协程开发框架开源项目

我要开发同款
匿名用户2019年06月14日
33阅读
开发技术PHP
所属分类Web应用开发、Web框架
授权协议Apache-2.0

作品详情

ESD是一个免费开源的,快速、简单的基于Swoole4.3最新特性的PHP协程开发框架。由SwooleDistributed与EasySwoole作者打造。ESD可用于构建高性能的Web系统、API、中间件、基础服务等等。

功能特性预览:

协程框架:基于Swoole4.3的原生协程框架,自带常驻内存以及Swoole其它功能的封装。

多种混合协议通讯:HTTP控制器与自定义路由TCP、UDP、WEB_SOCKET控制器

组件化:组件分为核心组件和应用组件,所有应用组件都是非必须的,开发者可以自定义,按需使用。

连接池:框架自带Mysql/Redis/ampq 高效连接池,且实现所有连接断线重连。开发者不用关心连接,相应组件已经实现。

切面编程:框架容器管理的所有对象,都可以使用AOP。使用AOP可以使用在不改变实例内部的情况下,对实例对象的行为进行控制。

分布式与微服务:提供分布式与微服务的插件组织

注解系统:框架提供大量可使用的注解,比如注解路由,注解事务,注解缓存,注解验证等。 框架均提供注解与非注解的使用方式。

Tracing链路追踪:通过加载Tracing插件可以实现服务链路性能的监控,支持微服务

灵活的注解功能

全局的依赖注入容器

基于PSR-7的HTTP消息实现

事件管理器

缓存

协程、异步任务投递

自定义用户进程

协程和同步阻塞客户端无缝自动切换

热更新自动Reload

强大的日志系统

组件化

ESD从设计之初就实现了组件化模式,达到模块解耦和代码复用的效果。

目前可用插件console-plugin https://github.com/esd-projects/console-plugin 控制台插件postgresql-plugin https://github.com/esd-projects/postgresql-plugin postgreSQL插件(由bearlord提供)mqtt-plugin https://github.com/esd-projects/mqtt-plugin MQTT服务器、MQTT客户端、MQTT路由redis-plugin https://github.com/esd-projects/redis-plugin redis插件easyroute-plugin https://github.com/esd-projects/easyroute-plugin 最方便的注解路由插件pack-plugin https://github.com/esd-projects/pack-plugin tcp,ws等自定义协议解析的pack插件tracing-plugin https://github.com/esd-projects/tracing-plugin 链路监控插件aop-plugin https://github.com/esd-projects/aop-plugin 提供AOP支持的插件amqp-plugin https://github.com/esd-projects/amqp-plugin AMQP插件(由李丹阳提供)mysql-plugin https://github.com/esd-projects/mysql-plugin mysql插件annotations-scan-plugin https://github.com/esd-projects/annotations-scan-plugin 扫描注解插件whoops-plugin https://github.com/esd-projects/whoops-plugin whoops插件,http调试用session-plugin https://github.com/esd-projects/session-plugin session插件cache-plugin https://github.com/esd-projects/cache-plugin cache插件,缓存actuator-plugin https://github.com/esd-projects/actuator-plugin actuator插件提供健康检查等框架默认端点服务security-plugin https://github.com/esd-projects/security-plugin 鉴权插件saber-plugin https://github.com/esd-projects/saber-plugin http客户端插件,Saberautoreload-plugin https://github.com/esd-projects/autoreload-plugin 自动reload插件,用于开发validate-plugin https://github.com/esd-projects/validate-plugin 验证插件,提供数据的验证uid-plugin https://github.com/esd-projects/uid-plugin uid插件,长连接用于绑定fd与uid的关系topic-plugin https://github.com/esd-projects/topic-plugin 主题插件,长连接用于发送订阅主题,符合MQTT规范scheduled-plugin https://github.com/esd-projects/scheduled-plugin 定时任务插件phpunit-plugin https://github.com/esd-projects/phpunit-plugin 单元测试插件blade-plugin https://github.com/esd-projects/blade-plugin blade渲染插件csvreader-plugin https://github.com/esd-projects/csvreader-plugin 读取解析csv的插件process-rpc-plugin https://github.com/esd-projects/process-rpc-plugin 进程通讯插件saber-cloud-plugin https://github.com/esd-projects/saber-cloud-plugin 声明试Web客户端,提供微服务访问circuitbreaker-plugin https://github.com/esd-projects/circuitbreaker-plugin 微服务的熔断器插件consul-plugin-plugin https://github.com/esd-projects/consul-plugin consul插件,提供服务注册,选举Docker运行环境(由anythink提供)➜dockerrun-it--rm-p8080:8080-v$PWD:/dataregistry.cn-beijing.aliyuncs.com/anythink/esd:latest___________________|____/___||_\|_\_____||_(_)_________|_|\___\||||||_)||||'_\|__||'_`_\/_\||______)||_|||_<||_||||||_|||||||__/|_____|____/|____/|_|\_\\__,_|_||_|\__|_|_||_||_|\___|ESDframeworkRuntimeEnvironmentversion1.5authorbyanythinkroot@f41132062911:/data#

dockerrun-it--rm-p8080:8080-v$PWD:/dataregistry.cn-beijing.aliyuncs.com/anythink/esd:latest

请在ESD根目录运行容器,否则修改$PWD为代码根路径(windows需要用%cd%替换$PWD),如果修改了端口请把8080修改为自己使用的端口.镜像启动后的目录即挂载到主机的代码目录,注意Mac系统无法使用inotify热加载功能。容器启动后按照安装步骤,运行框架。

性能

4核8GSSD盘腾讯云高IO型I2服务器压测,框架压测包含路由

worker_num=4

swooleab压测输出hello平均5.9QPS万

ESD框架ab压测输出hello平均3.6QPS万

SD框架ab压测输出hello平均1.3QPS万

压测数据来自:A-Smile

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论