重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
前言
最近在做的項目中有一個需求是要讓某個字段值根據記錄產生的日期和一定的組合規則按順序生成一個序列號,這個序列號不可重復,這原本是一個很常見的需求,沒有多想就寫好了。由于沒有考慮到并發的情況,到后面測試的時候才發現一個比較嚴重的問題,如果用戶同時操作產生的記錄,生成的序列號會出現重復。
經過討論和思考后有幾種解決方案,一是在數據庫表層加鎖,一是采用類似 redis 的消息隊列,還有就是通過文件鎖達到數據庫排他鎖的目的,鑒于時間和項目當前的情況,最后采用了通過文件鎖實現這個需求。
其實除了以上幾種方式,Odoo 本身就有一個模型(ir.sequence)是用于生成序列的,可以很方便地實現這個需求,因為之前一直沒有接觸過這個模塊,還是在項目之后的階段同事使用到了并且告訴我之后才知道原來有這么個好東西的存在。在這里我將會把我原本通過文件鎖實現的方式和通過 Odoo 自帶的ir.sequence實現的方式都記錄下來。
給文件加鎖 - fcntl
fcntl是 Python 標準庫里的一個模塊,用來對文件進行加鎖的操作。在實現中主要用到的是下面這個函數:
def flock(fd, operation): """ flock(fd, operation) Perform the lock operation op on file descriptor fd. See the Unix manual page for flock(2) for details. (On some systems, this function is emulated using fcntl().) """ pass
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。