本週主要新增了 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 修復
hyperf\redis
元件叢集模式,無法設定密碼的問題。
最佳化
- #2603 允許
hyperf/database
元件,whereNull
方法接受array
作為入參。
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
本作品採用《CC 協議》,轉載必須註明作者和本文連結