日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python自帶緩存lru_cache用法及擴展的使用

瀏覽:129日期:2022-07-28 11:55:45
目錄1. lru_cache的使用1.1 參數詳解1.2 基本用法1.3 進階用法2. functiontools.wrap裝飾器對lru_cache的影響2.1 多個裝飾器裝飾同一函數時的執行順序2.2 functiontools.wrap原理2.3 使用wrap裝飾器前后的變化3. 自制簡易的my_cache3.1 lru_cache提供的功能3.2 cache的核心部件3.3 my_cache的實現4. lru_cache緩存和redis緩存的區別5. 總結

本篇博客將結合python官方文檔和源碼詳細講述lru_cache緩存方法是怎么實現, 它與redis緩存的區別是什么, 在使用時碰上functiontools.wrap裝飾器時會發生怎樣的變化,以及了解它給我們提供了哪些功能然后在其基礎上實現我們自制的緩存方法my_cache。

1. lru_cache的使用1.1 參數詳解

以下是lru_cache方法的實現,我們看出可供我們傳入的參數有2個maxsize和typed,如果不傳則maxsize的默認值為128,typed的默認值為False。其中maxsize參數表示是的被裝飾的方法最大可緩存結果數量, 如果是默認值128則表示被裝飾方法最多可緩存128個返回結果,如果maxsize傳入為None則表示可以緩存無限個結果,你可能會疑惑被裝飾方法的n個結果是怎么來的,打個比方被裝飾的方法為def add(a, b):當函數被lru_cache裝飾時,我們調用add(1, 2)和add(3, 4)將會緩存不同的結果。如果 typed 設置為true,不同類型的函數參數將被分別緩存。例如, f(3) 和 f(3.0) 將被視為不同而分別緩存。

def lru_cache(maxsize=128, typed=False): if isinstance(maxsize, int):if maxsize < 0: maxsize = 0 elif maxsize is not None:raise TypeError(’Expected maxsize to be an integer or None’) def decorating_function(user_function):wrapper = _lru_cache_wrapper(user_function, maxsize, typed, _CacheInfo)return update_wrapper(wrapper, user_function) return decorating_function1.2 基本用法

在我們編寫接口時可能需要緩存一些變動不大的數據如配置信息,我們可能編寫如下接口:

@api.route('/user/info', methods=['GET'])@functools.lru_cache()@login_requiredef get_userinfo_list(): userinfos = UserInfo.query.all() userinfo_list = [user.to_dict() for user in userinfos] return jsonify(userinfo_list)

我們緩存了從數據庫查詢的用戶信息,下次再調用這個接口時將直接返回用戶信息列表而不需要重新執行一遍數據庫查詢邏輯,可以有效較少IO次數,加快接口反應速度。

1.3 進階用法

還是以上面的例子,如果發生用戶的刪除或者新增時,我們再請求用戶接口時仍然返回的是緩存中的數據,這樣返回的信息就和我們數據庫中的數據就會存在差異,所以當發生用戶新增或者刪除時,我們需要清除原先的緩存,然后再請求用戶接口時可以重新加載緩存。

@api.route('/user/info', methods=['POST'])@functools.lru_cache()@login_requiredef add_user(): user = UserInfo(name='李四') db.session.add(user) db.session.commit()# 清除get_userinfo_list中的緩存 get_userinfo_list = current_app.view_functions['api.get_machine_list'] cache_info = get_userinfo_list.cache_info() # cache_info 具名元組,包含命中次數 hits,未命中次數 misses ,最大緩存數量 maxsize 和 當前緩存大小 currsize # 如果緩存數量大于0則清除緩存 if cache_info[3] > 0: get_userinfo_list.cache_clear() return jsonify('新增用戶成功')

在上面這個用法中我們,如果我們把lru_cache裝飾器和login_require裝飾器調換位置時,上述的寫法將會報錯,這是因為login_require裝飾器中用了functiontools.wrap模塊進行裝飾導致的,具原因我們在下節解釋, 如果想不報錯得修改成如下寫法。

@api.route('/user/info', methods=['POST'])@login_require@functools.lru_cache()def add_user(): user = UserInfo(name='李四') db.session.add(user) db.session.commit()# 清除get_userinfo_list中的緩存 get_userinfo_list = current_app.view_functions['api.get_machine_list'] cache_info = get_userinfo_list.__wrapped__.cache_info() # cache_info 具名元組,包含命中次數 hits,未命中次數 misses ,最大緩存數量 maxsize 和 當前緩存大小 currsize # 如果緩存數量大于0則清除緩存 if cache_info[3] > 0: get_userinfo_list.__wrapped__.cache_clear() return jsonify('新增用戶成功')2. functiontools.wrap裝飾器對lru_cache的影響

在上節我們看到,因為@login_require和@functools.lru_cache()裝飾器的順序不同, 就導致了程序是否報錯, 其中主要涉及到兩點:

login_require裝飾器中是否用了@functiontools.wrap()裝飾器 @login_require和@functools.lru_cache()裝飾器的執行順序問題

當我們了解完這兩點后就可以理解上述寫法了。

2.1 多個裝飾器裝飾同一函數時的執行順序

這里從其他地方盜了一段代碼來解釋一下,如下:

def decorator_a(func): print(’Get in decorator_a’) def inner_a(*args,**kwargs):print(’Get in inner_a’)res = func(*args,**kwargs)return res return inner_adef decorator_b(func): print(’Get in decorator_b’) def inner_b(*args,**kwargs):print(’Get in inner_b’)res = func(*args,**kwargs)return res return inner_b@decorator_b@decorator_adef f(x): print(’Get in f’) return x * 2f(1)

輸出結果如下:

’Get in decorator_a’’Get in decorator_b’’Get in inner_b’’Get in inner_a’’Get in f’

是不是很像django中的中間件的執行順序,其實原理都差不多。

2.2 functiontools.wrap原理

引用其他博主的描述:

Python裝飾器(decorator)在實現的時候,被裝飾后的函數其實已經是另外一個函數了(函數名等函數屬性會發生改變),為了不影響,Python的functools包中提供了一個叫wraps的decorator來消除這樣的副作用。寫一個decorator的時候,最好在實現之前加上functools的wrap,它能保留原有函數的名稱和docstring。

補充:為了訪問原函數此函數會設置一個__wrapped__屬性指向原函數, 這樣就可以解釋上面1.3節中我們的寫法了。

2.3 使用wrap裝飾器前后的變化

未完待續。。。。。。。。。

3. 自制簡易的my_cache3.1 lru_cache提供的功能

lru_cache緩存裝飾器提供的功能有:

緩存被裝飾對象的結果(基礎功能) 獲取緩存信息 清除緩存內容 根據參數變化緩存不同的結果 LRU算法當緩存數量大于設置的maxsize時清除最不常使用的緩存結果

​ 從列出的功能可知,python自帶的lru_cache緩存方法可以滿足我們日常工作中大部分需求, 可是它不包含一個重要的特性就是,超時自動刪除緩存結果,所以在我們自制的my_cache中我們將實現緩存的超時過期功能。

3.2 cache的核心部件

在作用域內存在一個相對全局的字典變量cache={}

在作用域內設置相對全局的變量包含命中次數 hits,未命中次數 misses ,最大緩存數量 maxsize和 當前緩存大小 currsize

第二點中的緩存信息中增加緩存加入時間和緩存有效時間

3.3 my_cache的實現

待實現。。。。。。。。。。。。

4. lru_cache緩存和redis緩存的區別比較類型 lru_cache redis 緩存類型 緩存在app進程內存中 緩存在redis管理的內存中 分布式 只緩存在單個app進程中 可做分布式緩存 數據類型 hash 參數作為key,返回結果為value 有5種類型的數據結構 適用場景 比較小型的系統、單體應用 常用的緩存解決方案 功能 緩存功能但是缺少過期時間控制,但是使用上更加便捷 具備緩存需要的各種要素 5. 總結

綜上所述,python自帶的緩存功能使用于稍微小型的單體應用。優點是可以很方便的根據傳入不同的參數緩存對應的結果, 并且可以有效控制緩存的結果數量,在超過設置數量時根據LRU算法淘汰命中次數最少的緩存結果。缺點是沒有辦法對緩存過期時間進行設置。

到此這篇關于python自帶緩存lru_cache用法及擴展的使用的文章就介紹到這了,更多相關python自帶緩存lru_cache內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久一区二区三区电影| 欧美综合社区国产| 中文字幕亚洲精品乱码| 夜夜嗨一区二区| 欧美专区18| 欧美日韩国产一区精品一区| 不卡福利视频| 天堂√中文最新版在线| 欧美日韩一区二区三区在线电影| 亚洲精品激情| 国产精品自拍区| 视频在线在亚洲| 天堂va在线高清一区| 婷婷亚洲精品| 麻豆视频在线看| 影音先锋久久| 喷白浆一区二区| 91午夜精品| 亚洲另类视频| 日韩欧美中文字幕一区二区三区| 日本午夜精品| 久久久噜噜噜| 香蕉久久久久久久av网站| 欧美专区在线| 麻豆精品蜜桃视频网站| 久久精品亚洲人成影院| 免费在线观看视频一区| 国产美女久久| 91成人精品视频| 国产精品欧美在线观看| 久久久久国产精品一区二区| 亚洲精品少妇| 国产一区亚洲| 美女久久久精品| 欧美日韩免费观看一区=区三区 | 亚洲1234区| 首页国产欧美久久| а√天堂8资源在线| 一区二区三区午夜视频| 91一区二区三区四区| 亚洲精品动态| 99日韩精品| 久久国产精品成人免费观看的软件| 四虎在线精品| 五月天av在线| 久久精品99国产精品| 国产模特精品视频久久久久| 国产中文欧美日韩在线| 日韩精品久久理论片| 91久久久久| 日韩精品免费一区二区在线观看 | 久久av免费看| 日本一区二区三区中文字幕| 九一精品国产| 日韩啪啪电影网| 精品视频久久| 国产精品日韩精品中文字幕| 一区二区国产精品| 亚洲视频二区| 免费日本视频一区| 久久91导航| 国精品产品一区| 久久亚洲黄色| 麻豆精品在线播放| 精品国产91| 久久精品亚洲| 精品视频一区二区三区在线观看| 国产欧美一区| 欧美国产视频| 精品久久久久中文字幕小说| 国产精品亚洲一区二区在线观看| 国产亚洲一区二区手机在线观看| 久久精品91| 欧美日韩国产免费观看 | 香蕉国产精品| 久热re这里精品视频在线6| 香蕉久久国产| 国产精品网址| 国产一区二区三区不卡视频网站 | 国产精品分类| 福利一区和二区| 香蕉国产精品| 国产亚洲精品美女久久久久久久久久| 国产欧美日韩精品一区二区免费| 日韩精品a在线观看91| 免费亚洲婷婷| 欧美特黄视频| 久久久久黄色| 女同性一区二区三区人了人一| 男女激情视频一区| 免费在线欧美黄色| 精品欧美激情在线观看| 日韩精品成人| 欧美久久久网站| 国产福利电影在线播放| 黄色免费成人| 97久久超碰| 午夜国产精品视频| 国产精品99精品一区二区三区∴| 亚洲黄色中文字幕| 亚洲一区区二区| 欧美xxxx性| 亚洲精品无吗| japanese国产精品| 麻豆精品在线视频| 日韩一区二区三区在线看| 日韩精品一区二区三区免费观影| 日本免费新一区视频| 国产精品av久久久久久麻豆网| 国产日产精品_国产精品毛片| 99久久婷婷| 国产精选在线| 国产一区二区三区探花| 欧美有码在线| 99香蕉国产精品偷在线观看 | 日韩成人精品一区| 欧美日韩1区| 一区二区三区四区在线观看国产日韩| 欧美日韩视频免费观看| 四季av一区二区凹凸精品| 国产欧美日韩在线一区二区 | 99国产精品久久久久久久成人热| 国产一区二区三区免费在线 | 国产私拍福利精品视频二区| 亚洲激情五月| 99视频精品全国免费| 婷婷激情久久| 另类中文字幕国产精品| 超级白嫩亚洲国产第一| 中文一区一区三区高中清不卡免费| 麻豆成人av在线| 91精品国产乱码久久久久久久| 激情综合网站| 一区久久精品| 麻豆精品网站| 日韩欧美中文字幕电影| 日韩黄色在线观看| 国产精品久久久久久av公交车| 国产欧美日韩一级| 国产精选在线| 精品国产免费人成网站| 秋霞影视一区二区三区| 久久精品影视| 中文一区一区三区免费在线观| 久久av电影| 日韩成人精品一区二区三区 | 中文一区一区三区免费在线观| 一区二区91| 麻豆久久一区二区| 欧洲一级精品| 亚洲不卡视频| 国产精品片aa在线观看| 99成人在线视频| 日本久久二区| 日韩免费福利视频| 伊人国产精品| 在线手机中文字幕| 亚洲一区成人| 精品网站999| 久久99伊人| 精品三级在线| 鲁大师影院一区二区三区| 欧美黄色精品| 在线观看视频免费一区二区三区| 久久精品国产亚洲aⅴ| 久久精品网址| 国产精品午夜一区二区三区| 精品深夜福利视频| 亚洲人成高清| 国产麻豆久久| 国产精品1区| 亚洲综合不卡| 日韩精品2区| 国产欧美69| 一区二区精彩视频| 999久久久91| 中文字幕在线视频网站| 日本综合视频| 99在线观看免费视频精品观看| 国产一区二区三区国产精品| 亚洲啊v在线免费视频| 99久久亚洲精品蜜臀| 久久久国产精品网站| 国产欧美日韩精品一区二区免费| 国产一区成人| 亚洲国内精品| 激情视频网站在线播放色| 免费一级欧美在线观看视频| 欧美一级二级三级视频| 一区二区91| 午夜视频一区二区在线观看| 亚洲精品一区二区妖精| 亚洲伦乱视频| 国产综合色产| 99国产精品99久久久久久粉嫩| 欧美日韩一区二区综合| 首页国产精品| 三级在线观看一区二区| 日韩一级欧洲| 一区二区三区四区日韩|