更新内容
本周主要新增了 hyperf/scout, hyperf/resource 和 hyperf/resource-grpc 三个组件,并修复了一些组件的 🐛Bug,继续提升 Hyperf 的稳定性,发布于 2.0.14 版,建议用户使用以下命令更新此版本。
- Scout
Scout
为模型的全文搜索提供了一个简单的、基于驱动程序的解决方案。使用模型观察员,Scout
会自动同步你的搜索索引和模型记录。 目前,Scout
自带了一个 Elasticsearch
驱动;而编写自定义驱动程序很简单,你可以自由地使用自己的搜索实现来扩展 Scout
。
- Resource & ResourceGrpc
当构建 API
时,你往往需要一个转换层来联结你的 Model
模型和实际返回给用户的 JSON
响应。资源类能够让你以更直观简便的方式将模型和模型集合转化成 JSON
。
composer update "hyperf/*" -o
直接访问 官网 hyperf.io 或 文档 hyperf.wiki 查看更新内容
新增
- #1172 新增基于
laravel/scout
实现的组件hyperf/scout
, 可以通过搜索引擎进行模型查询。 - #1868 新增
Redis
组件的哨兵模式。 - #1969 新增组件
hyperf/resource
andhyperf/resource-grpc
,可以更加方便的将模型转化为 Response。
修复
- #2594 修复
hyperf/crontab
组件因为无法正常响应hyperf/signal
,导致无法停止的问题。 - #2601 修复命令
gen:model
因为getter
和setter
同时存在时,注释@property
会被@property-read
覆盖的问题。 - #2607 #2637 修复使用
RetryAnnotationAspect
时,会有一定程度内存泄露的问题。 - #2624 修复组件
hyperf/testing
因使用了guzzle 7.0
和CURL HOOK
导致无法正常工作的问题。 - #2632 #2635 修复
hyperfredis
组件集群模式,无法设置密码的问题。
优化
- #2603 允许
hyperf/database
组件,whereNull
方法接受array
作为入参。
关于 Hyperf
Hyperf 是基于 Swoole 4.5+
实现的高性能、高灵活性的 PHP 协程框架,内置协程服务器及大量常用的组件,性能较传统基于 PHP-FPM
的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于 PSR 标准 实现,基于强大的依赖注入设计,保证了绝大部分组件或类都是 可替换
与 可复用
的。
框架组件库除了常见的协程版的 MySQL 客户端
、Redis 客户端
,还为您准备了协程版的 Eloquent ORM
、WebSocket 服务端及客户端
、JSON RPC 服务端及客户端
、GRPC 服务端及客户端
、OpenTracing(Zipkin, Jaeger) 客户端
、Guzzle HTTP 客户端
、Elasticsearch 客户端
、Consul、Nacos 服务中心
、ETCD 客户端
、AMQP 组件
、Nats 组件
、Apollo、ETCD、Zookeeper、Nacos 和阿里云 ACM 的配置中心
、基于令牌桶算法的限流器
、通用连接池
、熔断器
、Swagger 文档生成
、Swoole Tracker
、Blade、Smarty、Twig、Plates 和 ThinkTemplate 视图引擎
、Snowflake 全局ID生成器
、Prometheus 服务监控
等组件,省去了自己实现对应协程版本的麻烦。
Hyperf 还提供了 基于 PSR-11 的依赖注入容器
、注解
、AOP 面向切面编程
、基于 PSR-15 的中间件
、自定义进程
、基于 PSR-14 的事件管理器
、Redis/RabbitMQ 消息队列
、自动模型缓存
、基于 PSR-16 的缓存
、Crontab 秒级定时任务
、Session
、i18n 国际化
、Validation 表单验证
等非常便捷的功能,满足丰富的技术场景和业务场景,开箱即用。
框架初衷
尽管现在基于 PHP 语言开发的框架处于一个百花争鸣的时代,但仍旧未能看到一个优雅的设计与超高性能的共存的完美框架,亦没有看到一个真正为 PHP 微服务铺路的框架,此为 Hyperf 及其团队成员的初衷,我们将持续投入并为此付出努力,也欢迎你加入我们参与开源建设。
设计理念
Hyperspeed + Flexibility = Hyperf
,从名字上我们就将 超高速
和 灵活性
作为 Hyperf 的基因。
- 对于超高速,我们基于 Swoole 协程并在框架设计上进行大量的优化以确保超高性能的输出。
- 对于灵活性,我们基于 Hyperf 强大的依赖注入组件,组件均基于 PSR 标准 的契约和由 Hyperf 定义的契约实现,达到框架内的绝大部分的组件或类都是可替换的。
基于以上的特点,Hyperf 将存在丰富的可能性,如实现 单体 Web 服务,API 服务,网关服务,分布式中间件,微服务架构,游戏服务器,物联网(IOT)等。
文档齐全
我们投入了大量的时间用于文档的建设以提供高质量的文档体验,以解决各种因为文档缺失所带来的问题,文档上也提供了大量的示例,对新手同样友好。
Hyperf 官方开发文档
生产可用
我们为组件进行了大量的单元测试以保证逻辑的正确,目前存在 1547
个单测共 4807
个断言条件,Hyperf 是一款经历过严酷的生产环境考验的一个项目,目前已有很多的大型互联网企业都已将 Hyperf 部署到了自己的生产环境上并稳定运行。
官网及交流
Github 👈👈👈👈👈 点 Star 支持我们
Gitee 码云 👈👈👈👈👈 点 Star 支持我们
Hyperf 官网
Hyperf 文档
Hyperf 交流群(已满): 862099724
Hyperf 交流 2 群: 811414891
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。