共计 2486 个字符,预计需要花费 7 分钟才能阅读完成。
更新内容
本周更新主要新增 极简 DB 组件
,Zookeeper 配置中心
,和 Session 组件
,以及为 视图组件 增加了 Twig
和 Plates
视图引擎的支持,同时为计划任务组件增加了集群执行的支持。 极简 DB 组件
主要为希望以简易和性能为首要诉求的场景提供支持,而无需庞大的 ORM,而配置中心组件也增加了 Zookeeper
作为配置中心的支持,以及大家期望已久的 Session 组件也在这个版本上线了,同时还修复了一些各个组件的 BUG,发布于 v1.1.6 版本。
更多细节可直接访问 官网 hyperf.io 或 文档 hyperf.wiki 查看。
新增
- #827 新增了极简的高性能的 DB 组件;
- #905 视图组件增加了
twig
模板引擎; - #911 定时任务支持多实例情况下,只运行单一实例的定时任务;
- #913 增加监听器
Hyperf\ExceptionHandler\Listener\ErrorExceptionHandler
; - #921 新增
Session
组件; - #931 阿波罗配置中心增加
strict_mode
,自动将配置转化成对应数据类型; - #933 视图组件增加了
plates
模板引擎; - #937 Nats 组件添加消费者消费和订阅事件;
- #941 新增
Zookeeper
配置中心;
变更
- #934 修改
WaitGroup
继承\Swoole\Coroutine\WaitGroup
;
修复
- #897 修复
Nats
消费者,pool
配置无效的 BUG; - #901 修复
GraphQL
组件,Factory
注解无法正常使用的 BUG; - #903 修复添加
hyperf/rpc-client
依赖后,init-proxy
脚本无法正常停止的 BUG; - #904 修复监听器监听
Hyperf\Framework\Event\BeforeMainServerStart
事件时,无法使用IO
操作的 BUG; - #906 修复
Hyperf\HttpMessage\Server\Request
端口获取有误的 BUG; - #907 修复
Nats
组件requestSync
方法,超时时间不准确的 BUG; - #909 修复
Parallel
内逻辑抛错后,无法正常停止的 BUG; - #925 修复因
Socket
无法正常建立,导致进程频繁重启的 BUG; - #932 修复
Translator::setLocale
在协程环境下,数据混淆的 BUG; - #940 修复
WebSocketClient::push
方法finish
参数类型错误;
优化
- #907 优化
Nats
消费者频繁重启; - #928
Hyperf\ModelCache\Cacheable::query
批量修改数据时,可以删除对应缓存; - #936 优化调用模型缓存
increment
时,可能因并发情况导致的数据有错;
关于 Hyperf
Hyperf 是基于 Swoole 4.4+
实现的高性能、高灵活性的 PHP 协程框架,内置协程服务器及大量常用的组件,性能较传统基于 PHP-FPM
的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于 PSR 标准 实现,基于强大的依赖注入设计,保证了绝大部分组件或类都是 可替换
与 可复用
的。
框架组件库除了常见的协程版的 MySQL 客户端
、Redis 客户端
,还为您准备了协程版的 Eloquent ORM
、WebSocket 服务端及客户端
、JSON RPC 服务端及客户端
、GRPC 服务端及客户端
、OpenTracing(Zipkin, Jaeger) 客户端
、Guzzle HTTP 客户端
、Elasticsearch 客户端
、Consul 客户端
、ETCD 客户端
、AMQP 组件
、Nats 组件
、Apollo 配置中心
、 阿里云 ACM 应用配置管理
、ETCD 配置中心
、 基于令牌桶算法的限流器
、 通用连接池
、 熔断器
、Swagger 文档生成
、Swoole Tracker
、Blade 和 Smarty 视图引擎
、Snowflake 全局 ID 生成器
等组件,省去了自己实现对应协程版本的麻烦。
Hyperf 还提供了 基于 PSR-11 的依赖注入容器
、 注解
、AOP 面向切面编程
、 基于 PSR-15 的中间件
、 自定义进程
、 基于 PSR-14 的事件管理器
、Redis/RabbitMQ 消息队列
、 自动模型缓存
、 基于 PSR-16 的缓存
、Crontab 秒级定时任务
、i18n 国际化
、Validation 表达验证
等非常便捷的功能,满足丰富的技术场景和业务场景,开箱即用。
框架初衷
尽管现在基于 PHP 语言开发的框架处于一个百花争鸣的时代,但仍旧未能看到一个优雅的设计与超高性能的共存的完美框架,亦没有看到一个真正为 PHP 微服务铺路的框架,此为 Hyperf 及其团队成员的初衷,我们将持续投入并为此付出努力,也欢迎你加入我们参与开源建设。
设计理念
Hyperspeed + Flexibility = Hyperf
,从名字上我们就将 超高速
和 灵活性
作为 Hyperf 的基因。
- 对于超高速,我们基于 Swoole 协程并在框架设计上进行大量的优化以确保超高性能的输出。
- 对于灵活性,我们基于 Hyperf 强大的依赖注入组件,组件均基于 PSR 标准 的契约和由 Hyperf 定义的契约实现,达到框架内的绝大部分的组件或类都是可替换的。
基于以上的特点,Hyperf 将存在丰富的可能性,如实现 单体 Web 服务,API 服务,网关服务,分布式中间件,微服务架构,游戏服务器,物联网(IOT)等。
文档齐全
我们投入了大量的时间用于文档的建设,以解决各种因为文档缺失所带来的问题,文档上也提供了大量的示例,对新手同样友好。
Hyperf 官方开发文档
生产可用
我们为组件进行了大量的单元测试以保证逻辑的正确,目前存在 1206
个单测共 3593
个断言条件,同时维护了高质量的文档,在 Hyperf 正式对外开放 (2019 年 6 月 20 日) 之前,便已经过了严酷的生产环境的考验,我们才正式的对外开放该项目,现在已有很多的大型互联网企业都已将 Hyperf 部署到了自己的生产环境上并稳定运行。
官网及交流
Github ???????????????????? 点 Star 支持我们
Gitee 码云 ???????????????????? 点 Star 支持我们
Hyperf 官网
Hyperf 文档
QQ 群: 862099724