内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

高效的Python通用對(duì)象池化庫如何使用

本文小編為大家詳細(xì)介紹“高效的Python通用對(duì)象池化庫如何使用”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“高效的Python通用對(duì)象池化庫如何使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識(shí)吧。

十載的香坊網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整香坊建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“香坊網(wǎng)站設(shè)計(jì)”,“香坊網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

對(duì)象池模式主要適用于以下應(yīng)用場景:
  • 資源受限的場景。比如,不需要可伸縮性的環(huán)境(CPU、內(nèi)存等物理資源有限),CPU性能不夠強(qiáng)勁,內(nèi)存比較緊張,垃圾收集,內(nèi)存抖動(dòng)會(huì)造成比較大的影響,需要提高內(nèi)存管理效率, 響應(yīng)性比吞吐量更為重要。

  • 在內(nèi)存中數(shù)量受限的對(duì)象。

  • 創(chuàng)建成本高的對(duì)象。

  • 大量的存活期短且初始化成本低的對(duì)象池化,以降低內(nèi)存分配和再分配成本,避免內(nèi)存碎片。

  • Python 的這樣的動(dòng)態(tài)語言,GC 是依靠引用技術(shù)來來保證對(duì)象不會(huì)過早的回收,某些場景下可能出現(xiàn)雖然創(chuàng)建了但是沒人使用的空閑期,導(dǎo)致對(duì)象被回收了??梢晕薪o對(duì)象池來保管。

Pond 介紹

Pond 是一個(gè) Python 中高效的通用對(duì)象池,具有性能好、內(nèi)存占用小、命中率高的特點(diǎn)?;诮平y(tǒng)計(jì)的根據(jù)頻率自動(dòng)回收的能力,能夠自動(dòng)調(diào)整每個(gè)對(duì)象池的空閑對(duì)象數(shù)量。

因?yàn)槟壳?Python 目前沒有比較好的、測試用例完備、代碼注釋完備、文檔完善的對(duì)象池化庫,同時(shí)目前的主流對(duì)象池庫也沒有比較智能的自動(dòng)回收機(jī)制。

Pond 可能是 Python 中第一個(gè)社區(qū)公開的測試用例完整,覆蓋率 90% 以上、代碼注釋完備、文檔完善的對(duì)象池化庫。

Pond 靈感來自于 Apache Commons Pool、Netty Recycler、HikariCP、Caffeine,集合了多家的優(yōu)點(diǎn)。

其次 Pond 通過使用近似計(jì)數(shù)的方式以極小的內(nèi)存空間統(tǒng)計(jì)每個(gè)對(duì)象池的使用頻率,并且自動(dòng)回收。

流量較為隨機(jī)平均的情況下,默認(rèn)策略和權(quán)重可以降低 48.85% 內(nèi)存占用,借取命中率 100%。

高效的Python通用對(duì)象池化庫如何使用

流量較為符合 2/8 定律的情況下,默認(rèn)策略和權(quán)重可以降低 45.7% 內(nèi)存占用, 借取命中率 100%。

高效的Python通用對(duì)象池化庫如何使用

設(shè)計(jì)概述

Pond 主要由 FactoryDict、Counter、PooledObjectTree 三部分以及一個(gè)單獨(dú)的回收線程構(gòu)成。

FactoryDict

使用 Pond 需要實(shí)現(xiàn)對(duì)象工廠 PooledObjectFactory,PooledObjectFactory 提供對(duì)象的創(chuàng)建、初始化、銷毀、驗(yàn)證等操作,由 Pond 調(diào)用。

所以為了讓對(duì)象池支持存放完全不同的對(duì)象,Pond 使用了一個(gè)字典來記錄每個(gè)工廠類的名稱和自己實(shí)現(xiàn)的工廠類的實(shí)例化對(duì)象。

每個(gè) PooledObjectFactory 應(yīng)該具備創(chuàng)建對(duì)象、銷毀對(duì)象、驗(yàn)證對(duì)象是否還可用、重置對(duì)象四個(gè)功能。

比較特別的是 Pond 支持自動(dòng)重置對(duì)象,因?yàn)槟承﹫鼍跋驴赡軙?huì)存在對(duì)象中要先賦值進(jìn)行傳遞,傳遞完又被回收的情況,為了避免污染建議這種場景下無比實(shí)現(xiàn)這個(gè)功能。

Counter

Counter 中保存了一個(gè)近似計(jì)數(shù)器。

PooledObjectTree

PooleedObjectTree 是個(gè)字典,每個(gè) key 對(duì)應(yīng)著一個(gè)先進(jìn)先出的隊(duì)列,這些隊(duì)列都是線程安全的。

每個(gè)隊(duì)列中保存著多個(gè) PooleedObject。PooledObejct 保存了創(chuàng)建時(shí)間、最后借出的時(shí)間以及實(shí)際需要的對(duì)象。

線程安全

Pond 的借用和回收都是線程安全的。Python 的 queue 模塊提供了一個(gè)適用于多線程編程的先進(jìn)先出(FIFO)數(shù)據(jù)結(jié)構(gòu)。它可以用來安全地在生產(chǎn)者和消費(fèi)者線程之間傳遞消息或其他數(shù)據(jù)。

鎖是調(diào)用者來處理的,所有多個(gè)線程能夠安全且容易的使用同樣的 Queue 實(shí)例工作。而 Pond 的借用和回收都是在操作 queue,所以基本可以認(rèn)為是線程安全的。

借出機(jī)制

在使用 Pond 借出一個(gè)對(duì)象時(shí),會(huì)先檢查想要借出的對(duì)象的種類是否已經(jīng)在 PooledObjectTree 存在,如果存在會(huì)檢查這個(gè)對(duì)象的對(duì)象池是否為空,如果為空會(huì)創(chuàng)建一個(gè)新的。

如果對(duì)象池中有多余的對(duì)象,會(huì)利用 queue 彈出一個(gè)對(duì)象并驗(yàn)證這個(gè)對(duì)象是否可用。如果不可用會(huì)自動(dòng)調(diào)用所屬的 Factory 清理銷毀該對(duì)象,同時(shí)清理它在 Python 中的 GC 計(jì)數(shù),讓它更快被 GC 回收,不斷拿取下一個(gè)直至有可用的。

如果這個(gè)對(duì)象可用,則會(huì)直接返回。當(dāng)然無論是從對(duì)象池中取出對(duì)象還是新創(chuàng)建了一個(gè)對(duì)象,都會(huì)利用 Counter 增加一個(gè)計(jì)數(shù)。

回收機(jī)制

回收一個(gè)對(duì)象時(shí)會(huì)判斷目標(biāo)對(duì)象池存不存在,如果存在會(huì)檢查對(duì)象池是否已經(jīng)滿了,滿了的話會(huì)自動(dòng)銷毀要?dú)w還的這個(gè)對(duì)象。

然后會(huì)檢查這個(gè)對(duì)象是否已經(jīng)被借出太長時(shí)間,如果超過了配置的最長時(shí)間同樣會(huì)被清理掉。

自動(dòng)回收

自動(dòng)回收時(shí)每隔一段時(shí)間,默認(rèn)是 300 s,就會(huì)執(zhí)行一次。自動(dòng)清理不經(jīng)常使用的對(duì)象池中的對(duì)象。

使用說明

你可以先安裝 Pond 的庫并且在你的項(xiàng)目中引用。

pip install pondpond
from pond import Pond, PooledObjectFactory, PooledObject

首先你需要聲明一個(gè)你想要放入的類型的對(duì)象的工廠類,比如下面的例子我們希望池化的對(duì)象是 Dog,所以我們先聲明一個(gè) PooledDogFactory 類,并且實(shí)現(xiàn) PooledObjectFactory。

class Dog:
 name: str
 validate_result:bool = True
class PooledDogFactory(PooledObjectFactory):
 def creatInstantce(self) -> PooledObject:
 dog = Dog()
 dog.name = "puppy"
 return PooledObject(dog)
 def destroy(self, pooled_object: PooledObject):
 del pooled_object
 def reset(self, pooled_object: PooledObject) -> PooledObject:
 pooled_object.keeped_object.name = "puppy"
 return pooled_object
 def validate(self, pooled_object: PooledObject) -> bool:
 return pooled_object.keeped_object.validate_result

接著你需要?jiǎng)?chuàng)建 Pond 的對(duì)象:

pond = Pond(borrowed_timeout=2,
 time_between_eviction_runs=-1,
 thread_daemon=True,
 eviction_weight=0.8)

Pond 可以傳遞一些參數(shù)進(jìn)去,分別代表:

borrowed_timeout :單位為秒,借出對(duì)象的最長期限,超過期限的對(duì)象歸還時(shí)會(huì)自動(dòng)銷毀不會(huì)放入對(duì)象池。

time_between_eviction_runs :單位為秒,自動(dòng)回收的間隔時(shí)間。

thread_daemon :守護(hù)線程,如果為 True,自動(dòng)回收的線程會(huì)隨著主線程關(guān)閉而關(guān)閉。

eviction_weight :自動(dòng)回收時(shí)權(quán)重,會(huì)將這個(gè)權(quán)重與最大使用頻次想乘,使用頻次小于這個(gè)值的對(duì)象池中的對(duì)象都會(huì)進(jìn)入清理步驟。

實(shí)例化工廠類:

factory = PooledDogFactory(pooled_maxsize=10, least_one=False)

所有繼承了 PooledObjectFactory 都會(huì)自帶構(gòu)造函數(shù),可以傳遞 pooled_maxsize 和 least_one 兩個(gè)參數(shù)。

pooled_maxsize:這個(gè)工廠類生成出的對(duì)象的對(duì)象池的最大能放置的數(shù)量。

least_one:如果為 True,在進(jìn)入自動(dòng)清理時(shí),這個(gè)工廠類生成出的對(duì)象的對(duì)象池會(huì)至少保留一個(gè)對(duì)象。

向 Pond 注冊這個(gè)工廠對(duì)象,默認(rèn)會(huì)使用 factory 的類名作為 PooledObjectTree 的 key :

pond.register(factory)

當(dāng)然你也可以自定義它的名字,名字會(huì)作為 PooledObjectTree 的 key:

pond.register(factory, name="PuppyFactory")

注冊成功后,Pond 會(huì)自動(dòng)根據(jù) factory 中設(shè)置的 pooled_maxsize 自動(dòng)開始創(chuàng)建對(duì)象直至填滿這個(gè)對(duì)象池。

借用和歸還對(duì)象:

pooled_object: PooledObject = pond.borrow(factory)
dog: Dog = pooled_object.use()
pond.recycle(pooled_object, factory)

當(dāng)然你可以用名字來進(jìn)行借用和歸還:

pooled_object: PooledObject = pond.borrow(name="PuppyFactory")
dog: Dog = pooled_object.use()
pond.recycle(pooled_object, name="PuppyFactory")

完全清理一個(gè)對(duì)象池:

pond.clear(factory)

通過名字清理一個(gè)對(duì)象池:

pond.clear(name="PuppyFactory")

正常情況下,你只需要使用上面的這些方法,生成對(duì)象和回收對(duì)象都是全自動(dòng)的。

讀到這里,這篇“高效的Python通用對(duì)象池化庫如何使用”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站標(biāo)題:高效的Python通用對(duì)象池化庫如何使用
標(biāo)題鏈接:http://m.rwnh.cn/article48/gdejhp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊自適應(yīng)網(wǎng)站、網(wǎng)站建設(shè)、電子商務(wù)云服務(wù)器、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
泌阳县| 蓬溪县| 民丰县| 宁强县| 南汇区| 三门县| 新巴尔虎左旗| 乌兰察布市| 麻栗坡县| 云南省| 吐鲁番市| 历史| 长宁区| 乐业县| 瑞丽市| 博湖县| 双牌县| 大冶市| 德兴市| 南华县| 衡水市| 澄江县| 昭苏县| 三河市| 柏乡县| 宣威市| 民乐县| 黄大仙区| 白银市| 辽阳市| 利川市| 竹溪县| 东源县| 扎囊县| 阜康市| 清原| 宁德市| 和龙市| 新乐市| 清镇市| 云林县|