hyperf/docs/zh-tw
李铭昕 fa5488e07a Merge branch 'master' into 3.1
# Conflicts:
#	src/coroutine/src/Traits/Container.php
2023-08-18 12:04:39 +08:00
..
component-guide Remove mirrors.aliyun.com/composer (#5778) 2023-06-01 12:38:34 +08:00
db Fixed docs for validatoin. (#5653) 2023-04-21 17:33:21 +08:00
eco Release v3.0.1 (#5295) 2023-01-09 08:06:39 +08:00
imgs Remove useless images 2022-11-15 12:08:55 +08:00
middleware Replace with native annotations (#5506) 2023-03-11 07:20:01 +08:00
quick-start Removed useless docs. (#6024) 2023-08-15 15:16:14 +08:00
sdks Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
tutorial Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
upgrade upgrade documents about websocket-server. (#5846) 2023-06-17 21:12:15 +08:00
amqp.md Added how to use swagger with validation. (#6050) 2023-08-18 10:22:49 +08:00
annotation.md Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
aop.md Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
async-queue.md Removed some deprecated methods from Hyperf\Di\Annotation\AbstractAnnotation. (#6040) 2023-08-16 20:45:43 +08:00
awesome-components.md Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
cache.md Upgrade docs about cache, command and logger. (#6037) 2023-08-16 16:20:08 +08:00
changelog.md Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
circuit-breaker.md Changed $value.timeout to $options.timeout for annotation CircuitBreaker. (#4848) 2022-06-16 14:36:55 +08:00
command.md Upgrade docs about cache, command and logger. (#6037) 2023-08-16 16:20:08 +08:00
communication.md Update communication.md (#5195) 2022-11-14 14:02:00 +08:00
config-center.md Removed useless docs. (#6024) 2023-08-15 15:16:14 +08:00
config.md Fix missing use for value (#5837) 2023-06-15 17:34:53 +08:00
constants.md Removed some deprecated methods from Hyperf\Di\Annotation\AbstractAnnotation. (#6040) 2023-08-16 20:45:43 +08:00
consul.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
contribute.md docs(contribute): update pull request url 2020-06-26 19:20:17 +08:00
controller.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
coroutine-server.md Update docs and translate 2021-05-09 23:23:33 +00:00
coroutine.md Removed some deprecated methods from Hyperf\Di\Annotation\AbstractAnnotation. (#6040) 2023-08-16 20:45:43 +08:00
crontab.md Update docs from crontab (#5443) 2023-02-22 17:41:23 +08:00
dag.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
devtool.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
di.md Removed some deprecated methods from Hyperf\Di\Annotation\AbstractAnnotation. (#6040) 2023-08-16 20:45:43 +08:00
distributed-transaction.md Remove mirrors.aliyun.com/composer (#5778) 2023-06-01 12:38:34 +08:00
donate.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
elasticsearch.md Release v2.1.16 (#3522) 2021-04-26 08:25:52 +08:00
enterprise-service.md Release v2.2.26 (#4544) 2022-02-21 09:27:49 +08:00
etcd.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
event.md Add Coroutine Style Server Lifecycle events Doc (#5445) 2023-03-17 09:49:11 +08:00
exception-handler.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
filesystem.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
graphql.md Upgrade the minimum php version to 8.0 for http-server. (#4306) 2021-12-01 16:19:47 +08:00
grpc.md Upgrade the minimum php version to 8.0 for http-server. (#4306) 2021-12-01 16:19:47 +08:00
guzzle.md Use Hyperf\Coroutine\Coroutine instead of Hyperf\Utils\Coroutine (#5623) 2023-04-12 12:36:10 +08:00
jet.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
json-rpc.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
kafka.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
lifecycle.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
logger.md Upgrade docs about cache, command and logger. (#6037) 2023-08-16 16:20:08 +08:00
memory.md Do not separate the docs folders by version, use git branch to distinguish the difference versions docs 2020-06-11 13:55:15 +08:00
metric.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
microservice.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
nacos.md Release v3.0.7 (#5431) 2023-02-18 06:40:54 +08:00
nano.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
nats.md Upgrade the minimum php version to 8.0 for http-server. (#4306) 2021-12-01 16:19:47 +08:00
nsq.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
paginator.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
phar.md Release v2.1.7 (#3284) 2021-02-22 08:56:22 +08:00
pool.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
process.md Update docs and translate 2023-01-02 23:32:23 +00:00
rate-limit.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
reactive-x.md Use Hyperf\Collection\Arr instead of Hyperf\Utils\Arr. (#5594) 2023-04-02 21:17:26 +08:00
README.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
redis.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
release-planning.md Update docs and translate 2023-01-02 23:32:23 +00:00
request.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
response.md Fixed docs for command model and resource. (#5659) 2023-04-23 17:51:40 +08:00
retry.md Update docs and translate 2023-01-02 23:32:23 +00:00
router.md Update docs and translate 2023-01-02 23:32:23 +00:00
rpc-multiplex.md Release v3.0.15 (#5611) 2023-04-07 16:46:41 +08:00
rpn.md Remove PHPUnit badge for rpn (#6014) 2023-08-11 09:44:28 +08:00
scout.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
service-register.md Update docs and translate 2023-01-02 23:32:23 +00:00
session.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
signal.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
snowflake.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
socketio-server.md Use Hyperf\Context\ApplicationContext instead of Hyperf\Utils\ApplicationContext. (#5621) 2023-04-11 15:57:32 +08:00
summary.md upgrade documents about websocket-server. (#5846) 2023-06-17 21:12:15 +08:00
swagger.md Added how to use swagger with validation. (#6050) 2023-08-18 10:22:49 +08:00
swoole-tracker.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
task.md Use Hyperf\Coroutine\Coroutine instead of Hyperf\Utils\Coroutine (#5623) 2023-04-12 12:36:10 +08:00
tcp-server.md Release v3.0.21 (#5738) 2023-05-18 10:28:58 +08:00
testing.md Adds RunTestsInCoroutine trait (#5867) 2023-06-20 13:01:15 +08:00
tracer.md Release v3.0.33 (#6054) 2023-08-18 11:54:00 +08:00
translation.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
utils.md Use Hyperf\Coroutine\Coroutine instead of Hyperf\Utils\Coroutine (#5623) 2023-04-12 12:36:10 +08:00
validation.md Fixed docs for validatoin. (#5653) 2023-04-21 17:33:21 +08:00
versions.md Merge remote-tracking branch 'origin/master' into 2.0 2020-06-19 19:10:12 +08:00
view-engine.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
view.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
watcher.md Upgrade docs about cache, command and logger. (#6037) 2023-08-16 16:20:08 +08:00
websocket-client.md Update docs and translate (#5262) 2022-12-27 13:37:04 +08:00
websocket-server.md upgrade documents about websocket-server. (#5846) 2023-06-17 21:12:15 +08:00

3.0 介紹

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

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

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

框架初衷

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

設計理念

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

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

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

生產可用

我們為元件進行了大量的單元測試以保證邏輯的正確,同時維護了高質量的文件,在 Hyperf 正式對外開放之前,便已經過了嚴酷的生產環境的考驗,我們才正式的對外開放該專案,至今,已有大量的大型/中小型網際網路公司在生產環境使用 Hyperf。