python 執行緒安全的 單例 實現 日誌分級
什麼叫 單例 模式
多次初始化 只返回 同一個物件 叫做單例模式
為什麼 要使用單例模式
- 程式碼 中 有些 物件 比如 日誌物件 為了防止 多次初始化 可以使用單例模式
- 有些 模型 物件 體積龐大, 載入緩慢, 必須使用 單例模式
python 單例 執行緒安全的 實現方式
import threading
class SingletonType(type):
_instance_lock = threading.Lock()
def __call__(cls, *args, **kwargs):
if not hasattr(cls, "_instance"):
with SingletonType._instance_lock:
if not hasattr(cls, "_instance"):
cls._instance = super(SingletonType,cls).__call__(*args, **kwargs)
return cls._instance
class Foo(metaclass=SingletonType):
def __init__(self,name):
self.name = name
print(name)
obj1 = Foo('name2')
obj2 = Foo('name1')
print(obj1,obj2)
# 測試結果 init 函式 只被執行了一次
# python3 singlon.py
# name2
# <__main__.Foo object at 0x7f7cd9b04860> <__main__.Foo object at 0x7f7cd9b04860>
使用 單例 封裝 日誌物件
- 實現日誌單例
- 實現日誌 分級 輸出檔案
- 實現日誌 按照 每週 分檔案儲存
Singleton.py
#!/usr/bin/python
# -*- coding:utf-8 -*-
'''
@File : Singleton.py
@Time : 2020/12/14 14:17:11
@Author : lmk
@Version : 1.0
'''
import threading
class SingletonType(type):
_instance_lock = threading.Lock()
def __call__(cls, *args, **kwargs):
if not hasattr(cls, "_instance"):
with SingletonType._instance_lock:
if not hasattr(cls, "_instance"):
cls._instance = super(SingletonType,cls).__call__(*args, **kwargs)
return cls._instance
if __name__ == '__main__':
pass
singleton_log.py
#!/usr/bin/python
# -*- coding:utf-8 -*-
'''
@File : singleton_log.py
@Time : 2020/12/14 14:26:05
@Author : lmk
@Version : 1.0
'''
from scripts.Singleton import SingletonType
from logging import Logger
import logging # 引入logging模組
import os
import time
from gen_log.a_log_config import info_log_path,err_log_path
class singleLogger(metaclass=SingletonType):
def __init__(self):
# 第一步,建立一個logger
self.logger = logging.getLogger()
self.logger.setLevel(logging.INFO) # Log等級總開關
# 第二步,建立一個handler,用於寫入日誌檔案
# fh = logging.FileHandler(info_log_path,mode="w")
info_fh = logging.handlers.TimedRotatingFileHandler(info_log_path,when="W0")
# fh.setLevel(logging.DEBUG) # 輸出到file的log等級的開關
# 設定日誌過濾器
info_filter = logging.Filter()
info_filter.filter = lambda record: record.levelno <= logging.WARNING # 設定過濾等級
info_fh.setLevel(logging.INFO)
info_fh.addFilter(info_filter)
# fh = logging.FileHandler(info_log_path,mode="w")
err_fh = logging.handlers.TimedRotatingFileHandler(err_log_path,when="W0")
# fh.setLevel(logging.DEBUG) # 輸出到file的log等級的開關
err_filter = logging.Filter()
err_filter.filter = lambda record: record.levelno > logging.WARNING
err_fh.setLevel(logging.ERROR)
err_fh.addFilter(err_filter)
# 第三步,定義handler的輸出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: \n%(message)s\n")
info_fh.setFormatter(formatter)
err_fh.setFormatter(formatter)
# 第四步,將logger新增到handler裡面
self.logger.addHandler(info_fh)
self.logger.addHandler(err_fh)
logger = singleLogger().logger
相關文章
- qt 單獨執行緒實現日誌寫入功能QT執行緒
- c++ 運算子過載、執行緒安全實現單例C++執行緒單例
- 【設計模式】實現執行緒安全單例模式的五種方式設計模式執行緒單例
- Python實現執行緒安全佇列Python執行緒佇列
- 靜態內部類實現的單例模式是執行緒安全的單例模式執行緒
- 不使用synchronized和lock,如何實現一個執行緒安全的單例?synchronized執行緒單例
- Qt 中用Q_GLOBAL_STATIC來實現執行緒安全的單例模式QT執行緒單例模式
- Python簡單實現多執行緒例子Python執行緒
- 單例模式執行緒安全reorder問題單例模式執行緒
- python執行緒池的實現Python執行緒
- 你的單例模式真的是執行緒安全的嗎?單例模式執行緒
- 如何看待Spring下單例模式與執行緒安全的矛盾Spring單例模式執行緒
- C# Debug執行日誌Logs的實現C#
- 5招教你實現多執行緒場景下的執行緒安全!執行緒
- Map實現執行緒安全的3種方式執行緒
- python實現自定義執行緒池Python執行緒
- 多執行緒併發鎖分類以及簡單例項執行緒單例
- python 字典是不是執行緒安全的Python執行緒
- 多執行緒 日誌 和截圖的問題執行緒
- 多執行緒非同步日誌系統,高效、強悍的實現方式:雙緩衝!執行緒非同步
- 單例模式(上)—如何優雅地保證執行緒安全問題單例模式執行緒
- 單例模式(上)---如何優雅地保證執行緒安全問題單例模式執行緒
- 【iOS – OC】OC基礎-單例的實現 & 提醒自己注意多執行緒問題iOS單例執行緒
- 執行緒池的實現執行緒
- 執行緒池的實現原始碼及應用舉例執行緒原始碼
- 【Java多執行緒】執行緒安全的集合Java執行緒
- 執行緒安全佇列(使用互斥鎖進行實現)執行緒佇列
- Java 執行緒池中的執行緒複用是如何實現的?Java執行緒
- Java併發實戰一:執行緒與執行緒安全Java執行緒
- Python程式和執行緒例項詳解Python執行緒
- Python實現投遞多執行緒任務Python執行緒
- 單例模式中可能存在的一些問題(執行緒安全問題)單例模式執行緒
- 什麼叫執行緒安全,舉例說明。執行緒
- Java多執行緒的實現Java執行緒
- 執行緒池的實現原理執行緒
- SpringBoot執行緒池和Java執行緒池的實現原理Spring Boot執行緒Java
- Java多執行緒之—Synchronized方式和CAS方式實現執行緒安全效能對比Java執行緒synchronized
- Java中實現執行緒安全HashSet的幾種方法 | baeldungJava執行緒