使用LRU加速python應用

来源:https://www.cnblogs.com/MikeZhang/archive/2023/03/19/2023031901-pythonLRUTest.html
-Advertisement-
Play Games

操作系統 :CentOS 7.6.1810_x64 Python 版本 : 3.9.12 一、背景描述 使用python開發過程中,會遇到需要使用緩存加速應用的情況,比如下麵這些場景: 數據轉換加速 字元串時間轉換成int時間戳; 字元串時間轉換成datetime類型; ... 數據解析加速 byt ...


操作系統 :CentOS 7.6.1810_x64

Python 版本 : 3.9.12

一、背景描述

使用python開發過程中,會遇到需要使用緩存加速應用的情況,比如下麵這些場景:

  • 數據轉換加速

字元串時間轉換成int時間戳;

字元串時間轉換成datetime類型;

...

  • 數據解析加速

bytes數據轉換為int(數據包解析場景的埠、序列號等);

bytes數據轉換為string(數據包解析場景的ip地址等);

...

本文提供兩種實現方式來加速應用,這裡記錄下,希望對你有幫助。 

二、具體實現

1、使用python自帶的OrderedDict實現LRU

實現思路:

1)使用OrderedDict作為緩存,並設置大小;

2)第一次解析時,將解析結果加入緩存;

3)緩存元素數量超過設定數量,執行pop操作; 

示例代碼如下 :

from collections import OrderedDict
class LRU:

    def __init__(self, func, maxsize=128):
        self.func = func
        self.maxsize = maxsize
        self.cache = OrderedDict()

    def __call__(self, *args):
        if args in self.cache:
            value = self.cache[args]
            self.cache.move_to_end(args)
            return value
        value = self.func(*args)
        if len(self.cache) >= self.maxsize:
            self.cache.popitem(False)
        self.cache[args] = value
        return value

2、使用lru-dict庫實現LRU

pypi地址:https://pypi.org/project/lru-dict/

github地址:https://github.com/amitdev/lru-dict

 

安裝lru-dict庫:

pip install lru-dict

示例代碼:

from lru import LRU
l = LRU(5)         # Create an LRU container that can hold 5 items

print l.peek_first_item(), l.peek_last_item()  #return the MRU key and LRU key
# Would print None None

for i in range(5):
   l[i] = str(i)
print l.items()    # Prints items in MRU order
# Would print [(4, '4'), (3, '3'), (2, '2'), (1, '1'), (0, '0')]

print l.peek_first_item(), l.peek_last_item()  #return the MRU key and LRU key
# Would print (4, '4') (0, '0')

l[5] = '5'         # Inserting one more item should evict the old item
print l.items()
# Would print [(5, '5'), (4, '4'), (3, '3'), (2, '2'), (1, '1')]

由於lru-dict庫是使用c實現的,使用源代碼安裝可能存在環境問題,可直接使用pypi上面提供的預編譯whl文件:

 說明:

1)源碼包為 lru-dict-1.1.8.tar.gz;

2)本文使用的whl文件是 lru_dict-1.1.8-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl ;

3)可從以下途徑獲取上述文件:

關註微信公眾號(聊聊博文,文末可掃碼)後回覆 2023031901 獲取。

三、運行效果

這裡演示下兩種實現方式的具體效果,並做下對比。

1、測試用例1(lru庫實現)

 測試代碼:

 運行效果:

 運行時間:15.046 秒

2、測試用例2( OrderedDict實現)

測試代碼:

 運行效果:

 運行時間: 28.934秒

 結論:

lru-dict庫比較快。

說明:

1)使用OrderedDict實現LRU的優點在於不用安裝額外的庫;

2)lru-dict是使用c語言開發的第三方庫,需要使用pip進行安裝,性能比較好,但和平臺相關性比較強; 

四、資源下載

本文涉及示例代碼及whl文件,可從百度網盤獲取:

https://pan.baidu.com/s/1N6wWHhMkvXcyVI5mEhn1JA 

關註微信公眾號(聊聊博文,文末可掃碼)後回覆 2023031901 獲取。

微信公眾號:

  • E-Mail : [email protected]
  • 轉載請註明出處,謝謝!
    您的分享是我們最大的動力!

    -Advertisement-
    Play Games
    更多相關文章
    • 去年公司由於不斷發展,內部自研系統越來越多,所以後來搭建了一個日誌收集平臺,並將日誌收集功能以二方包形式引入自研系統,避免每個自研系統都要建立一套自己的日誌模塊,節約了開發時間,管理起來也更加容易。 這篇文章主要介紹ELK最新版本的搭建,二方包的介紹可以看小霸王的另外一篇文章。 ...
    • SpringBoot接收參數相關註解 1.基本介紹 SpringBoot接收客戶端提交數據/參數會使用到相關註解 詳解@PathVariable、@RequestHeader、@ModelAttribute、@RequestParam、@CookieValue、@RequestBody 2.接參數相 ...
    • 前言 緣起 實驗室的學弟問我為什麼他使用nvcc命令報錯,起先我以為他用的是老師給的root賬戶,按照參考文獻1便可以解決問題。 但由於並非root用戶,/usr/local下沒有cuda,於是便無法按照參考1中的方法去做。 這裡提供一種方法,其實是參考了文獻2,但似乎是歪打正著,因為2要解決的問題 ...
    • 瞭解過 Hex 六邊形架構、Onion 洋蔥架構、Clean 整潔架構的同學可以將本篇文章介紹的實踐方法與自身項目代碼架構對比並互通有無,共同改進。沒瞭解過上述架構的同學可以學習一種新的架構方法,並嘗試將其應用到業務項目中,降低項目維護成本,提高效率。 本文提及的架構主要指項目組織的“代碼架構”,註... ...
    • 在C++/Qt網路通訊模塊設計與實現(三)中提到了一個概念,即接受者所依附的線程;關註我微信公眾號的技術朋友留言對該概念還是不解,這節就單獨講述這個概念的理論與實際應用,這種應用無處不在,因為與Qt的信號槽、線程相關,大家需掌握。接下來從 Qt::ConnectionType,示例源碼,結果論證,歸 ...
    • 發現報錯:RuntimeError: NCCL error in: /pytorch/torch/lib/c10d/ProcessGroupNCCL.cpp:784, unhandled system error想在linux上跑跑mmclassification中的resnet網路,但是報錯,查閱... ...
    • Pandas庫專為數據分析而設計,它是使Python成為強大而高效的數據分析環境的重要因素。 一、Pandas數據結構 1、import pandas as pd import numpy as np import matplotlib.pyplot as plt 2、S1=pd.Series([‘ ...
    • 本文主要介紹 Tomcat Native Library 安裝及使用,文中所使用到的軟體版本:Centos 7.9.2009、Java 1.8.0_321、Tomcat 8.5.84、APR 1.7.0。 1、APR 1.1、APR 簡介 APR(Apache Portable Runtime) 是 ...
    一周排行
      -Advertisement-
      Play Games
    • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
    • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
    • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
    • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
    • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
    • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
    • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
    • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
    • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
    • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...