Hyperf 釋出 v2.1 版本,企業級的 PHP 微服務雲原生協程框架

huangzhhui發表於2020-12-28

經過幾個月的開發除錯和內部線上試用,終於在今天釋出了 V2.1 版本,它並沒有增加一些跨時代的功能,但卻是為了 V3.0 版本的到來打好了基礎。

本週主要 提升了部分元件的依賴版本,提升了最低PHP版本(>=7.3),並增加了對 Swow 驅動的適配。釋出於 2.1.0 版。

如需更新到 v2.1.0 版本,只需要將 Hyperf 相關元件的依賴版本改為 2.1.* 即可,詳情請見 更新指南

警告:所有的程式碼變動已在更新內容中註明,除了根據更新指南更新外,仍需仔細閱讀 更新內容,以免出現遺漏

直接訪問 官網 hyperf.io 或 文件 hyperf.wiki 檢視更新內容

依賴升級

  • 升級 php 版本到 >=7.3
  • 升級元件 phpunit/phpunit 版本到 ^9.0
  • 升級元件 guzzlehttp/guzzle 版本到 ^6.0|^7.0
  • 升級元件 vlucas/phpdotenv 版本到 ^5.0
  • 升級元件 endclothing/prometheus_client_php 版本到 ^1.0
  • 升級元件 twig/twig 版本到 ^3.0
  • 升級元件 jcchavezs/zipkin-opentracing 版本到 ^0.2.0
  • 升級元件 doctrine/dbal 版本到 ^3.0
  • 升級元件 league/flysystem 版本到 ^1.0|^2.0

移除

  • 移除 Hyperf\Amqp\Builder 已棄用的成員變數 $name
  • 移除 Hyperf\Amqp\Message\ConsumerMessageInterface 已棄用的方法 consume()
  • 移除 Hyperf\AsyncQueue\Driver\Driver 已棄用的成員變數 $running
  • 移除 Hyperf\HttpServer\CoreMiddleware 已棄用的方法 parseParameters()
  • 移除 Hyperf\Utils\Coordinator\Constants 已棄用的常量 ON_WORKER_STARTON_WORKER_EXIT
  • 移除 Hyperf\Utils\Coordinator 已棄用的方法 get()
  • 移除配置檔案 rate-limit.php, 請使用 rate_limit.php
  • 移除無用的類 Hyperf\Resource\Response\ResponseEmitter
  • 將元件 hyperf/paginatorhyperf/database 依賴中移除。
  • 移除 Hyperf\Utils\Coroutine\Concurrent 中的方法 stats()

變更

  • 方法 Hyperf\Utils\Coroutine::parentId 返回父協程的協程 ID

    • 如果在主協程中,則會返回 0。
    • 如果在非協程環境中使用,則會丟擲 RunningInNonCoroutineException 異常。
    • 如果協程環境已被銷燬,則會丟擲 CoroutineDestroyedException 異常。
  • Hyperf\Guzzle\CoroutineHandler

    • 刪除了 execute() 方法。
    • 方法 initHeaders() 將會返回初始化好的 Header 列表, 而不是直接將 $headers 賦值到客戶端中。
    • 刪除了 checkStatusCode() 方法。
  • #2720 不再在方法 PDOStatement::bindValue() 中設定 data_type,已避免字串索引中使用整形時,導致索引無法被命中的問題。

  • #2871StreamInterface 中獲取資料時,使用 (string) $body 而不是 $body->getContents(),因為方法 getContents() 只會返回剩餘的資料,而非全部資料。

  • #2909 允許設定重複的中介軟體。

  • #2935 修改了 Exception Formatter 的預設規則。

  • #2979 命令列 gen:model 不再自動將 decimal 格式轉化為 float

棄用

  • Hyperf\AsyncQueue\Signal\DriverStopHandler 將會在 v2.2 版本中棄用, 請使用 Hyperf\Process\Handler\ProcessStopHandler 代替。
  • Hyperf\Server\SwooleEvent 將會在 v3.0 版本中棄用, 請使用 Hyperf\Server\Event 代替。

新增

  • #2659 #2663 新增了 Swow 驅動支援。
  • #2671 新增監聽器 Hyperf\AsyncQueue\Listener\QueueHandleListener,用來記錄非同步佇列的執行日誌。
  • #2923 新增類 Hyperf\Utils\Waiter,可以用來等待一個協程結束。
  • #3001 新增方法 Hyperf\Database\Model\Collection::columns(),類似於 array_column
  • #3002Json::decodeJson::encode 新增引數 $depth$flags

修復

  • #2741 修復自定義程式無法在 Swow 驅動下使用的問題。

最佳化

  • #3009 最佳化了 prometheus,使其支援 httpshttp 協議。

Hyperf 是基於 Swoole 4.5+ 實現的高效能、高靈活性的 PHP 協程框架,內建協程伺服器及大量常用的元件,效能較傳統基於 PHP-FPM 的框架有質的提升,提供超高效能的同時,也保持著極其靈活的可擴充套件性,標準元件均基於 PSR 標準 實現,基於強大的依賴注入設計,保證了絕大部分元件或類都是 可替換可複用 的。

框架元件庫除了常見的協程版的 MySQL 客戶端Redis 客戶端,還為您準備了協程版的 Eloquent ORMWebSocket 服務端及客戶端JSON RPC 服務端及客戶端GRPC 服務端及客戶端OpenTracing(Zipkin, Jaeger) 客戶端Guzzle HTTP 客戶端Elasticsearch 客戶端Consul、Nacos 服務中心ETCD 客戶端AMQP 元件Nats 元件Apollo、ETCD、Zookeeper、Nacos 和阿里雲 ACM 的配置中心基於令牌桶演算法的限流器通用連線池熔斷器Swagger 文件生成Swoole TrackerBlade、Smarty、Twig、Plates 和 ThinkTemplate 檢視引擎Snowflake 全域性ID生成器Prometheus 服務監控 等元件,省去了自己實現對應協程版本的麻煩。

Hyperf 還提供了 基於 PSR-11 的依賴注入容器註解AOP 面向切面程式設計基於 PSR-15 的中介軟體自定義程式基於 PSR-14 的事件管理器Redis/RabbitMQ 訊息佇列自動模型快取基於 PSR-16 的快取Crontab 秒級定時任務Sessioni18n 國際化Validation 表單驗證 等非常便捷的功能,滿足豐富的技術場景和業務場景,開箱即用。

儘管現在基於 PHP 語言開發的框架處於一個百花爭鳴的時代,但仍舊未能看到一個優雅的設計與超高效能的共存的完美框架,亦沒有看到一個真正為 PHP 微服務鋪路的框架,此為 Hyperf 及其團隊成員的初衷,我們將持續投入併為此付出努力,也歡迎你加入我們參與開源建設。

Hyperspeed + Flexibility = Hyperf,從名字上我們就將 超高速靈活性 作為 Hyperf 的基因。

  • 對於超高速,我們基於 Swoole 協程並在框架設計上進行大量的最佳化以確保超高效能的輸出。
  • 對於靈活性,我們基於 Hyperf 強大的依賴注入元件,元件均基於 PSR 標準 的契約和由 Hyperf 定義的契約實現,達到框架內的絕大部分的元件或類都是可替換的。

基於以上的特點,Hyperf 將存在豐富的可能性,如實現 單體 Web 服務,API 服務,閘道器服務,分散式中介軟體,微服務架構,遊戲伺服器,物聯網(IOT)等。

我們投入了大量的時間用於文件的建設以提供高質量的文件體驗,以解決各種因為文件缺失所帶來的問題,文件上也提供了大量的示例,對新手同樣友好。
Hyperf 官方開發文件

我們為元件進行了大量的單元測試以保證邏輯的正確,目前存在 1660 個單測共 5116 個斷言條件,Hyperf 是一款經歷過嚴酷的生產環境考驗的一個專案,目前已有很多的大型網際網路企業都已將 Hyperf 部署到了自己的生產環境上並穩定執行。

Github ????? 點 Star 支援我們
Gitee 碼雲 ????? 點 Star 支援我們
Hyperf 官網
Hyperf 文件
Hyperf 交流群(已滿): 862099724
Hyperf 交流 2 群: 811414891
釘釘群 一群(已滿): 34538367
釘釘群 二群: 34488757

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章