logging 模塊因許可權問題寫入日誌失敗

来源:https://www.cnblogs.com/edisonfish/archive/2023/06/02/17452538.html
-Advertisement-
Play Games

哈嘍大家好,我是鹹魚 今天跟大家分享一個使用 Python 的 logging 模塊寫入日誌文件時遇到的許可權問題,不知道你們有沒有遇到過 ## 1.案例現象 今天上班的時候手機簡訊收到了 zabbix 告警,但是發現了不對勁的地方:微信沒有收到告警信息,按理說簡訊跟微信應該是同時收到告警信息的 鹹魚 ...


哈嘍大家好,我是鹹魚

今天跟大家分享一個使用 Python 的 logging 模塊寫入日誌文件時遇到的許可權問題,不知道你們有沒有遇到過

1.案例現象

今天上班的時候手機簡訊收到了 zabbix 告警,但是發現了不對勁的地方:微信沒有收到告警信息,按理說簡訊跟微信應該是同時收到告警信息的

鹹魚這邊的 zabbix 是通過一個 python 腳本實現連接微信介面並向微信發送告警消息

上 zabbix 看看 action log
image

發現 zabbix 發送告警到微信的操作執行失敗了,報錯如下:

Traceback (most recent call last):
  File "/home/zabbix/alert.py", line 24, in <module>
    logger = create_logger(log_path)
  File "/home/zabbix/alert.py", line 10, in create_logger
    file_handler = logging.FileHandler(log_path)
  File "/usr/lib64/python3.9/lib/python3.9/logging/__init__.py", line 1142, in __init__
    StreamHandler.__init__(self, self._open())
  File "/usr/lib64/python3.9/lib/python3.9/logging/__init__.py", line 1171, in _open
    return open(self.baseFilename, self.mode, encoding=self.encoding,
PermissionError: [Errno 13] Permission denied: '/var/log/myapp/myapp_20230525.log'

2.定位問題

在開始定位前先介紹一下 zabbix 發送告警信息到微信的流程:

  1. zabbix 調用 /home/zabbix/alert.py 腳本實現告警信息發送到微信
  2. /home/zabbix/alert.py 腳本的大體邏輯就是首先通過 logging 模塊將告警內容寫進本地日誌,然後返回一個 logger 對象
  3. 再將 logger 對象以及其他參數傳進 send_msg 函數裡面,將告警信息發送到微信端

python 腳本 alert.py中創建並寫入日誌文件的代碼如下:

import logging
import time
...

...
def create_logger(log_path):
    # 創建一個 logger 對象
    logger = logging.getLogger(__name__)
    logger.setLevel(logging.DEBUG)

    # 創建一個文件處理器,將日誌寫入指定的文件中
    file_handler = logging.FileHandler(log_path)
    file_handler.setLevel(logging.DEBUG)

    # 創建一個格式化器,定義日誌的格式
    formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
    file_handler.setFormatter(formatter)

    # 將文件處理器添加到 logger 對象中
    logger.addHandler(file_handler)

    return logger

if __name__ == '__main__':
    log_path = '/var/log/myapp/myapp_%s.log' % time.strftime('%Y%m%d', time.localtime())
    logger = create_logger(log_path)
	...

看報錯信息裡面有 PermissionError ,首先定位到應該是許可權問題

看下這個日誌文件的信息

[root@localhost /var/log/myapp]# ll /var/log/myapp/myapp_20230525.log
-rw-r--r-- 1 root root 300 5月  25 14:09 /var/log/myapp/myapp_20230525.log

可以看到屬主屬組都是 root,其他用戶只有讀的許可權

我們再來看一下 zabbix 進程

[root@localhost /var/log/myapp]# ps -ef | grep [z]abbix
zabbix    31076      1  0 3月16 ?       00:00:00 /usr/sbin/zabbix_server -c /etc/zabbix/zabbix_server.conf

可以看到 zabbix 進程是 zabbix 用戶啟動的,因為 /var/log/myapp/myapp_20230525.log 的許可權是644且屬主屬組都是 root

所以說 zabbix 用戶調用 alert.py 腳本時發現寫入日誌因為沒有許可權而失敗,導致腳本運行崩潰

3.排查問題

到這裡基本就能知道是什麼原因了,但是還有一點疑問:只有 /var/log/myapp/myapp_20230525.log 這個日誌的屬主屬組都是 root ,其餘日誌文件都是 zabbix

我們知道,在 Python 的 logging 模塊中,日誌文件的屬主是由操作系統的文件系統決定的,而不是由 logging 模塊本身決定。當使用 logging 模塊創建日誌文件時,它會使用操作系統提供的預設文件創建方式

這意味著日誌文件的屬主將取決於當前運行 Python 程式的用戶或進程的許可權和身份。

看樣子應該是有人使用 root 用戶執行過這個 python 腳本,導致生成的這個日誌文件 myapp_20230525.log 屬主是 root,後面等 zabbix 自己去執行這個腳本(zabbix 用戶)的時候發現沒有許可權寫東西進 myapp_20230525.log 裡面,這才導致微信收不了告警信息

後面拷打了一下同事(其實是執行了 history 命令看操作記錄 )才知道昨晚同事在終端上手動跑了一下這個 python 腳本,又因為預設登錄用戶是 root,導致生成的日誌文件屬主屬組都是 root

如何解決:修改一下日誌文件的屬主屬組即可

chown zabbix.zabbix /var/log/myapp/myapp_20230525.log

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我們在初學 Java 編程的時候,總是感覺很枯燥乏味,想著做點可以交互的小系統,可以讓用戶自由輸入,系統可以接收做出反映。這就要介紹一下 Java 中的 Scanner 類了。 ...
  • 通過python來開發web應用,可以產簡化了web開發的流程,功能和函數庫也是非常豐富,我們也是開箱即用,目前比較流程的WEB框架就是Flask和django。 > 根據2020年JetBrains Python開發人員調查,Django和Flask是迄今為止最受歡迎的兩個Python Web框架 ...
  • 在今年2月14日的時候,Keycloak 團隊宣佈他們正在棄用大多數 Keycloak 適配器。其中包括Spring Security和Spring Boot的適配器,這意味著今後Keycloak團隊將不再提供針對Spring Security和Spring Boot的集成方案。但是,如此強大的Ke ...
  • # 1.初識列表(list) **列表由一系列按特定順序排列的數據元素組成**。可以將任何類型數據元素加入列表中,其中的數據元素之間沒有任何關係。鑒於列表通常包含多個數據元素,給列表指定一個表示覆數的名稱是個不錯的選擇。 在python中,用方括弧[]來表示列表,並用逗號來分隔其中的數據元素。編寫程 ...
  • # 出錯信息 ``` 我使用flask時,運行後出現下麵的錯誤:Traceback (most recent call last): File "D:/github/lind-python/test-web.py", line 1, in from flask import Flask File " ...
  • ## 引言 之前說的做自動記錄 Todo 執行過程中消耗的時間的[Todo 項目]( https://github.com/circler3/TodoTrack ),由於想持續保持程式執行,就放棄了 `Spectre.Console.Cli`,後來隨著命令越來越多,自己處理覺得很是麻煩,想了想要不試 ...
  • 經常坐地鐵,卻不知道地鐵多少條線路?哪個站下車?今天就帶領大家熟悉並繪製深圳地鐵路線圖。 WPF在繪製矢量圖方面有非常強大的優勢,利用WPF可以繪製出各種矢量圖形,如線,圓,多邊形,矩形,及組合圖形。今天以繪製深圳地鐵路線圖為例,簡述WPF在圖形繪製方面的一些知識,僅供學習分享使用,如有不足之處,還 ...
  • 在本篇博客中,我將介紹如何在WPF應用程式中使用OwinSelfHost和Swagger來創建自托管的Web API。我們將使用WPF作為我們的應用程式界面,OwinSelfHost來自托管我們的Web API,並使用Swagger來為我們的API生成文檔。 首先,確保你的電腦上已安裝了以下組件: ...
一周排行
    -Advertisement-
    Play Games
  • 前言 插件化的需求主要源於對軟體架構靈活性的追求,特別是在開發大型、複雜或需要不斷更新的軟體系統時,插件化可以提高軟體系統的可擴展性、可定製性、隔離性、安全性、可維護性、模塊化、易於升級和更新以及支持第三方開發等方面的能力,從而滿足不斷變化的業務需求和技術挑戰。 一、插件化探索 在WPF中我們想要開 ...
  • 歡迎ReaLTaiizor是一個用戶友好的、以設計為中心的.NET WinForms項目控制項庫,包含廣泛的組件。您可以使用不同的主題選項對項目進行個性化設置,並自定義用戶控制項,以使您的應用程式更加專業。 項目地址:https://github.com/Taiizor/ReaLTaiizor 步驟1: ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • Channel 是乾什麼的 The System.Threading.Channels namespace provides a set of synchronization data structures for passing data between producers and consume ...
  • efcore如何優雅的實現按年分庫按月分表 介紹 本文ShardinfCore版本 本期主角: ShardingCore 一款ef-core下高性能、輕量級針對分表分庫讀寫分離的解決方案,具有零依賴、零學習成本、零業務代碼入侵適配 距離上次發文.net相關的已經有很久了,期間一直在從事java相關的 ...
  • 前言 Spacesniffer 是一個免費的文件掃描工具,通過使用樹狀圖可視化佈局,可以立即瞭解大文件夾的位置,幫助用戶處理找到這些文件夾 當前系統C盤空間 清理後系統C盤空間 下載 Spacesniffer 下載地址:https://spacesniffer.en.softonic.com/dow ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • 一、ReZero簡介 ReZero是一款.NET中間件 : 全網唯一開源界面操作就能生成API , 可以集成到任何.NET6+ API項目,無破壞性,也可讓非.NET用戶使用exe文件 免費開源:MIT最寬鬆協議 , 一直從事開源事業十年,一直堅持開源 1.1 純ReZero開發 適合.Net Co ...
  • 一:背景 1. 講故事 停了一個月沒有更新文章了,主要是忙於寫 C#內功修煉系列的PPT,現在基本上接近尾聲,可以回頭繼續更新這段時間分析dump的一些事故報告,有朋友微信上找到我,說他們的系統出現了大量的http超時,程式不響應處理了,讓我幫忙看下怎麼回事,dump也抓到了。 二:WinDbg分析 ...
  • 開始做項目管理了(本人3年java,來到這邊之後真沒想到...),天天開會溝通整理需求,他們講話的時候忙裡偷閑整理一下常用的方法,其實語言還是有共通性的,基本上看到方法名就大概能猜出來用法。出去打水的時候看到外面太陽好好,真想在外面坐著曬太陽,回來的時候好兄弟三年前送給我的鍵盤D鍵不靈了,在打"等待 ...