Linux 服務 | rsyslog

来源:https://www.cnblogs.com/rendd/archive/2023/02/18/17133192.html
-Advertisement-
Play Games

rsyslog 是實現日誌功能的服務,用來採集日誌信息。 主配置文件/etc/rsyslog.conf中,可以設置日誌的處理方式。 MODULES 預設開啟的兩個 imuxsock、imjournal imuxsock 提供對本地系統日誌記錄的支持 imjournal 提供對systemd日誌的訪問 ...


rsyslog 是實現日誌功能的服務,用來採集日誌信息。

主配置文件/etc/rsyslog.conf中,可以設置日誌的處理方式。


MODULES

  • 預設開啟的兩個 imuxsock、imjournal

  • imuxsock 提供對本地系統日誌記錄的支持

  • imjournal 提供對systemd日誌的訪問

  • imudp 提供 UDP 方式系統日誌接收

  • imtcp 提供 TCP 方式系統日誌接收


RULES

  • 規則設置的格式是filter action

  • filter過濾後的日誌,送到action處理

  • 多個 rule 用分號隔開*.info;mail.none

過濾器 filter

  • 基於設施.優先順序的過濾器。例:kern.* /dev/console

    • kern是產生日誌的設施,*是日誌優先順序

    • 設施類型(facility)
      kern 內核信息
      user 用戶程式產生的相關信息
      mail 郵件系統信息
      daemon 守護進程產生的信息
      auth pam認證系統信息
      syslog 日誌系統自身信息
      authpriv ssh、ftp等登錄信息
      cron 系統執行定時任務產生的信息
      lpr 列印相關信息
      mark 服務內部的信息,時間標識
      uucp Unix-to-Unix Copy 兩個unix之間的相關通信
      local0-local7 保留,本地使用

      • 多個設施用,隔開

      • *表示所有設施

    • 日誌優先順序(priority)

      • debug (7) , info (6) , notice (5) , warning (4) , err (3) , crit (2) , alert (1) , emerg (0)

      • none會記錄沒有指定級別的信息

      • *記錄所有級別信息

      • 多個級別用,隔開

    • 記錄日誌內容的設置
      . 等級高於符號後面的信息會記錄
      .= 只有符號後面等級的信息會記錄
      .! 除了符號後面等級,其他的都會記錄(註意前面需要先有其他過濾規則,否則什麼不記錄)

  • 基於屬性的過濾器。例:msg, contains, "error"

    • :msg是要比較的日誌屬性,contains是要執行的比較操作,"error"是比較的值

    • 比較操作

      • contains 匹配提供的字元串值是否是屬性的一部分,如果不區分大小寫,使用contains_i
      • isequal 比較屬性和值是否相等
      • startswith 屬性是否以指定字元串開始(startswith_i)
      • regex 正則表達式(POSIX BRE 基本正則)匹配
      • ereregex 正則表達式(POSIX ERE 擴展正則)匹配
      • isempty 判斷屬性是否為空,不需要 value
  • 基於表達式的過濾器

    • 使用了 rsyslog 自定義的腳本語言RainerScript構建複雜的 filter。

執行操作 action

多個 action 用&連接

action 後面加;模板名可以使用模板格式化日誌

  • 日誌保存到日誌文件。例cron.* /var/log/cron.log

    • 表示所有 cron 執行的日誌都放在 cron.log 中

    • 通常生成日誌時會同步到日誌文件。前面加-則忽略同步

    • 可以動態生成日誌文件,用預定義輸出路徑模板,併在文件名前加?

  • 通過網路發送日誌信息

    *.* @192.168.0.1        # 使用 UDP 發送,預設埠514
    
    *.* @@example.com:18    # 使用 TCP 發送到埠18, 預設10514
    
    *.* @(z9)[2001:db8::1]  # UDP, ipv6,使用zlib級別9壓縮
    
    • @表示用 UTP 協議發送

    • @@表示用 TCP 協議發送

    • z9表示用 zlib 壓縮日誌級別,可設置 1-9。可以不設置壓縮

  • 丟棄日誌,例cron.* ~

    • 使用~

模板 template

所有系統日誌都可以用指定模板進行格式化

  • 創建模板

    $template TEMPLATE_NAME,"text %PROPERTY% more text", [OPTION]

    • TEMPLATE_NAME為模板名稱

    • "text %PROPERTY% more text"為模板內容

    • OPTION為模板功能,可設置sqlstdsql,資料庫存儲時用到

  • 生成動態文件名

    $template DynamicFile,"/var/log/test_logs/%timegenerated%-test.log"
    *.* ?DynamicFile
    
    • timegenerated屬性從日誌信息中提取出信息時間戳
  • 屬性

    • 屬性放在兩個%之間,可以取得日誌信息中的內容。

    • 可用的屬性列表man rsyslog.conf


服務確認

  • 修改配置後重啟服務

    systemctl restart rsyslog.service

  • 寫入測試 log

    logger -p syslog.info -t test "this is a test log."

  • 在系統日誌文件/var/log/messages中確認寫入的測試 log



rsyslog 能滿足幾乎所有的日誌處理。

以後有用到其他內容再來補充


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

-Advertisement-
Play Games
更多相關文章
  • nano /etc/motd // _ooOoo_ // // o8888888o // // 88" . "88 // // (| ^_^ |) // // O\ = /O // // ____/` '\____ // // .' \\| |// `. // // / \\||| : |||// ...
  • 本文敘述的問題的根源在於對C#基礎知識掌握不牢固,從而在遇到難以理解的問題時浪費了大量時間; 在此也警示自己,該啃啃基礎書籍了! 話不多說,先上代碼: 先看問題 services.AddEasyCaching(option => { option.UseHybrid(config => { .... ...
  • ###語法: select * from 表名 where 條件1 start with 條件2 connect by 條件3; 條件2: 是根結點的限定語句,當然可以放寬限定條件,以取得多個根結點,實際就是多棵樹。 條件3: 是連接條件,其中用PRIOR表示上一條記錄,比如 CONNECT BY ...
  • 1.說說顯示實現介面和隱式實現介面的區別。 2.說說file訪問修飾的作用。 3.說說什麼是原始字元串。 4.C#10 中struct有什麼改進? 5.說說C#10中Lambda表達式的新特點。 6.說說對於泛型特性的理解。 7.說說在ASP.NET Core7中,依賴註入中的方法註入需要註意什麼? ...
  • 我相信很多人看了其他的貼子,都沒有成功部署,因為裡面有很多暗坑。接下來博主就一步一步給大家講明白,帶領大家部署 先基本的發佈 操作:右擊web項目的《發佈》按鈕。選文件 配置發佈屬性 部署模式,建議選框架依賴,且安裝對應的運行時框架,可共用系統級版本的 .NET Core,如果框架依賴部署不行,可以 ...
  • 在日常工作中,我們有時會需要修改字體的顏色來突出文本重點,讓讀者更容易抓住文章要點。在今天這篇文章中,我將為大家介紹如何以編程方式,在Word更改字體顏色。本文將分為兩部分分別介紹如何實現此操作。以下是我整理的步驟及方法,並附上C#/VB.NET代碼供大家參考。 更改段落字體顏色 更改特定文本字體顏 ...
  • C# 委托原理刨析,和事件原理刨析,外加兩者對比,應該是目前全網講的最細的帖子了吧。從委托介紹=》基本使用=》框架應用=》原理分析=》事件原理分析=》兩者對比 ...
  • 更詳細的可參考基於VirtualBox搭建Linux(CentOS 7)虛擬機環境(學習必備技能) - 碼霸霸 (lupf.cn) 使用虛擬機的時候,需要自己執行自己不確定操作時,一定要提前進行快照 1.軟體 VirtualBox官網下載最新的VirtualBox,地址:https://www.vi ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...