v1.0.2 更新內(nèi)容
本次更新涉及以下組件
hyperf/database
hyperf/di
hyperf/event
hyperf/http-server
hyperf/logger
hyperf/redis
hyperf/contract
接入 Travis CI,目前 Hyperf 共存在 426 個(gè)單測,1124 個(gè)斷言; #25
完善了對 Redis::connect 方法的參數(shù)支持; #29
Fixed修復(fù)了 HTTP Server 會(huì)被 WebSocket Server 影響的問題(WebSocket Server 尚未發(fā)布);
修復(fù)了代理類部分注解沒有生成的問題;
修復(fù)了數(shù)據(jù)庫連接池在單測環(huán)境下會(huì)無法獲取連接的問題;
修復(fù)了 co-phpunit 在某些情況下不能按預(yù)期運(yùn)行的問題;
修復(fù)了模型事件 creating, updating ... 運(yùn)行與預(yù)期不一致的問題;
修復(fù)了 flushContext 方法在單測環(huán)境下不能按預(yù)期運(yùn)行的問題;
關(guān)于 HyperfHyperf 是基于 Swoole 4.3+ 實(shí)現(xiàn)的高性能、高靈活性的 PHP 協(xié)程框架,內(nèi)置協(xié)程服務(wù)器及大量常用的組件,性能較傳統(tǒng)基于 PHP-FPM 的框架有質(zhì)的提升,提供超高性能的同時(shí),也保持著極其靈活的可擴(kuò)展性,標(biāo)準(zhǔn)組件均均基于 PSR 標(biāo)準(zhǔn) 實(shí)現(xiàn),基于強(qiáng)大的依賴注入設(shè)計(jì),保證了絕大部分組件或類都是 可替換 與 可復(fù)用 的。
? ?
框架組件庫除了常見的協(xié)程版的 MySQL 客戶端、Redis 客戶端,還為您準(zhǔn)備了協(xié)程版的 Eloquent ORM、JSON RPC 服務(wù)的及客戶端、GRPC 服務(wù)端及客戶端、Zipkin (OpenTracing) 客戶端、Guzzle HTTP 客戶端、Elasticsearch 客戶端、Consul 客戶端、ETCD 客戶端、AMQP 組件、Apollo 配置中心、阿里云 ACM 應(yīng)用配置管理、基于令牌桶算法的限流器、通用連接池、熔斷器、Swagger 文檔生成 等組件,省去了自己實(shí)現(xiàn)對應(yīng)協(xié)程版本的麻煩,Hyperf 還提供了 基于 PSR-11 的依賴注入容器、注解、AOP 面向切面編程、基于 PSR-15 的中間件、自定義進(jìn)程、基于 PSR-14 的事件管理器、Redis/RabbitMQ 消息隊(duì)列、自動(dòng)模型緩存、基于 PSR-16 的緩存 等非常便捷的功能,滿足豐富的技術(shù)場景和業(yè)務(wù)場景,開箱即用。
盡管現(xiàn)在基于 PHP 語言開發(fā)的框架處于一個(gè)百花爭鳴的時(shí)代,但仍舊未能看到一個(gè)優(yōu)雅的設(shè)計(jì)與超高性能的共存的完美框架,亦沒有看到一個(gè)真正為 PHP 微服務(wù)鋪路的框架,此為 Hyperf 及其團(tuán)隊(duì)成員的初衷,我們將持續(xù)投入并為此付出努力,也歡迎你加入我們參與開源建設(shè)。
設(shè)計(jì)理念Hyperspeed + Flexibility = Hyperf,從名字上我們就將 超高速 和 靈活性 作為 Hyperf 的基因。
? ?
對于超高速,我們基于 Swoole 協(xié)程并在框架設(shè)計(jì)上進(jìn)行大量的優(yōu)化以確保超高性能的輸出。 ??
對于靈活性,我們基于 Hyperf 強(qiáng)大的依賴注入組件,組件均基于 PSR 標(biāo)準(zhǔn) 的契約和由 Hyperf 定義的契約實(shí)現(xiàn),達(dá)到框架內(nèi)的絕大部分的組件或類都是可替換的。 ??
基于以上的特點(diǎn),Hyperf 將存在豐富的可能性,如實(shí)現(xiàn) Web 服務(wù),網(wǎng)關(guān)服務(wù),分布式中間件,微服務(wù)架構(gòu),游戲服務(wù)器,物聯(lián)網(wǎng)(IOT)等。
文檔齊全我們投入了大量的時(shí)間用于文檔的建設(shè),以解決各種因?yàn)槲臋n缺失所帶來的問題,文檔上也提供了大量的示例,對新手同樣友好。
生產(chǎn)可用我們?yōu)榻M件進(jìn)行了大量的單元測試以保證邏輯的正確,同時(shí)維護(hù)了高質(zhì)量的文檔,在 Hyperf 正式對外開放(2019年6月20日)之前,便已在一家 C輪 和一家 B輪 互聯(lián)網(wǎng)公司上線了多個(gè)服務(wù)并以穩(wěn)定的姿態(tài)完美的運(yùn)行了超過半年時(shí)間,經(jīng)過了嚴(yán)酷的生產(chǎn)環(huán)境 (如618) 的考驗(yàn),我們才正式的對外開放該項(xiàng)目。 ??
官網(wǎng)及交流Github <- 點(diǎn) Star 支持我們 ??
Hyperf 官網(wǎng) ??
QQ 群: 862099724 ??
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/31809.html
摘要:在實(shí)際開發(fā)項(xiàng)目中,有時(shí)我們會(huì)用到自定義按鈕因?yàn)橐粋€(gè)項(xiàng)目中,眾多的頁面,為了統(tǒng)一風(fēng)格,我們會(huì)重復(fù)用到很多相同或相似的按鈕,這時(shí)候,自定義按鈕組件就派上了大用場,我們把定義好的按鈕組件導(dǎo)出,在全局引用,就可以在其他組件隨意使用啦,這樣可以大幅度 在實(shí)際開發(fā)項(xiàng)目中,有時(shí)我們會(huì)用到自定義按鈕;因?yàn)橐粋€(gè)項(xiàng)目中,眾多的頁面,為了統(tǒng)一風(fēng)格,我們會(huì)重復(fù)用到很多相同或相似的按鈕,這時(shí)候,自定義按鈕組件就...
摘要:代碼整潔之道整潔的代碼不僅僅是讓人看起來舒服,更重要的是遵循一些規(guī)范能夠讓你的代碼更容易維護(hù),同時(shí)降低幾率。另外這不是強(qiáng)制的代碼規(guī)范,就像原文中說的,。里式替換原則父類和子類應(yīng)該可以被交換使用而不會(huì)出錯(cuò)。注釋好的代碼是自解釋的。 JavaScript代碼整潔之道 整潔的代碼不僅僅是讓人看起來舒服,更重要的是遵循一些規(guī)范能夠讓你的代碼更容易維護(hù),同時(shí)降低bug幾率。 原文clean-c...
摘要:接著我之前寫的一篇有關(guān)前端面試題的總結(jié),分享幾道比較經(jīng)典的題目第一題考點(diǎn)作用域,運(yùn)算符栗子都會(huì)進(jìn)行運(yùn)算,但是最后之后輸出最后一個(gè)也就是那么其實(shí)就是而且是個(gè)匿名函數(shù),也就是屬于,就輸出第二和第三個(gè)都是類似的,而且作用域是都是輸出最后一個(gè)其實(shí)就 接著我之前寫的一篇有關(guān)前端面試題的總結(jié),分享幾道比較經(jīng)典的題目: 第一題: showImg(https://segmentfault.com/im...
對比內(nèi)容UCloudStackZStackVMwareQingCloud騰訊TStack華為云Stack優(yōu)勢總結(jié)?基于公有云自主可控?公有云架構(gòu)私有化部署?輕量化/輕運(yùn)維/易用性好?政府行業(yè)可復(fù)制案例輕量化 IaaS 虛擬化平臺(tái)?輕量化、產(chǎn)品成熟度高?業(yè)內(nèi)好評(píng)度高?功能豐富、交付部署快?中小企業(yè)案例多全套虛擬產(chǎn)品及云平臺(tái)產(chǎn)品?完整生態(tài)鏈、技術(shù)成熟?比較全面且健全的渠道?產(chǎn)品成熟度被市場認(rèn)可,市場占...
摘要:能跨平臺(tái)地設(shè)置及使用環(huán)境變量讓這一切變得簡單,不同平臺(tái)使用唯一指令,無需擔(dān)心跨平臺(tái)問題安裝方式改寫使用了環(huán)境變量的常見如在腳本多是里這么配置運(yùn)行,這樣便設(shè)置成功,無需擔(dān)心跨平臺(tái)問題關(guān)于跨平臺(tái)兼容,有幾點(diǎn)注意 cross-env能跨平臺(tái)地設(shè)置及使用環(huán)境變量, cross-env讓這一切變得簡單,不同平臺(tái)使用唯一指令,無需擔(dān)心跨平臺(tái)問題 1、npm安裝方式 npm i --save-de...
摘要:引入的模塊引入的使用將打包打包的拆分將一部分抽離出來物理地址拼接優(yōu)化打包速度壓縮代碼,這里使用的是,同樣在的里面添加 const path = require(path); //引入node的path模塊const webpack = require(webpack); //引入的webpack,使用lodashconst HtmlWebpackPlugin = require(ht...
閱讀 3369·2021-11-11 16:54
閱讀 3525·2021-10-11 10:58
閱讀 1265·2021-08-30 09:41
閱讀 1809·2019-08-30 15:54
閱讀 2035·2019-08-30 14:00
閱讀 2709·2019-08-29 17:13
閱讀 1678·2019-08-29 15:19
閱讀 614·2019-08-29 15:14