更新內容
本週更新主要爲新增 hyperf/nats 組件,Nats 是一個開源、輕量級、高性能的雲原生消息系統,本組件使 Hyperf 與 Nats 進行交互提供了可能性。同時對 Consul 集羣作爲服務註冊中心提供了支持,以及爲 Redis 集羣提供了客戶端支持,同時我們還修復了一些組件的 🐛Bug,使 Hyperf 1.1.* 系列版本更加的健壯了,發佈於 1.1.5 版,建議使用 1.1 的用戶更新。
直接訪問 官網 hyperf.io 或 文檔 hyperf.wiki 查看。
新增
- #812 新增計劃任務在集羣下僅執行一次的支持;
- #820 新增 hyperf/nats 組件;
-
#832 新增
Hyperf\Utils\Codec\Json
; -
#833 新增
Hyperf\Utils\Backoff
; -
#852 爲
Hyperf\Utils\Parallel
新增clear()
方法來清理所有已添加的回調; -
#854 新增
Hyperf\GraphQL\GraphQLMiddleware
用於解析 GraphQL 請求; - #859 新增 Consul 集羣的支持,現在可以從 Consul 集羣中拉取服務提供者的節點信息;
- #873 新增 Redis 集羣的客戶端支持;
修復
- #831 修復 Redis 客戶端連接在 Redis Server 重啓後不會自動重連的問題;
-
#835 修復
Request::inputs
方法的默認值參數與預期效果不一致的問題; - #841 修復數據庫遷移在多數據庫的情況下連接無效的問題;
- #844 修復 Composer 閱讀器不支持根命名空間的用法的問題;
-
#846 修復 Redis 客戶端的
scan
,hScan
,zScan
,sScan
無法使用的問題; - #850 修復 Logger group 在 name 一樣時不生效的問題;
優化
- #832 優化了 Response 對象在轉 JSON 格式時的異常處理邏輯;
-
#840 使用
\Swoole\Timer::*
來替代swoole_timer_*
函數; - #859 優化了 RPC 客戶端去 Consul 獲取健康的節點信息的邏輯;
關於 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 官方開發文檔
生產可用
我們爲組件進行了大量的單元測試以保證邏輯的正確,目前存在 1163
個單測共 3427
個斷言條件,同時維護了高質量的文檔,在 Hyperf 正式對外開放(2019年6月20日)之前,便已經過了嚴酷的生產環境的考驗,我們才正式的對外開放該項目,現在已有很多的大型互聯網企業都已將 Hyperf 部署到了自己的生產環境上並穩定運行。
官網及交流
Github 👈👈👈👈👈 點 Star 支持我們
Gitee 碼雲 👈👈👈👈👈 點 Star 支持我們
Hyperf 官網
Hyperf 文檔
QQ 羣: 862099724