日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式分享
[導(dǎo)讀]在嵌入式系統(tǒng)和服務(wù)器開(kāi)發(fā)中,日志系統(tǒng)是故障排查和運(yùn)行監(jiān)控的核心組件。本文基于Linux環(huán)境實(shí)現(xiàn)一個(gè)輕量級(jí)C語(yǔ)言日志庫(kù),支持DEBUG/INFO/WARN/ERROR四級(jí)日志分級(jí),并實(shí)現(xiàn)按大小滾動(dòng)的文件輪轉(zhuǎn)機(jī)制。該設(shè)計(jì)在某物聯(lián)網(wǎng)網(wǎng)關(guān)項(xiàng)目中穩(wěn)定運(yùn)行,日均處理日志量達(dá)500MB,未出現(xiàn)性能瓶頸。


嵌入式系統(tǒng)和服務(wù)器開(kāi)發(fā)中,日志系統(tǒng)是故障排查和運(yùn)行監(jiān)控的核心組件。本文基于Linux環(huán)境實(shí)現(xiàn)一個(gè)輕量級(jí)C語(yǔ)言日志庫(kù),支持DEBUG/INFO/WARN/ERROR四級(jí)日志分級(jí),并實(shí)現(xiàn)按大小滾動(dòng)的文件輪轉(zhuǎn)機(jī)制。該設(shè)計(jì)在某物聯(lián)網(wǎng)網(wǎng)關(guān)項(xiàng)目中穩(wěn)定運(yùn)行,日均處理日志量達(dá)500MB,未出現(xiàn)性能瓶頸。


一、核心架構(gòu)設(shè)計(jì)

1. 分層模塊結(jié)構(gòu)

log_lib/

├── log.h          // 公共接口頭文件

├── log_core.c     // 核心處理邏輯

├── log_file.c     // 文件輪轉(zhuǎn)實(shí)現(xiàn)

└── log_config.c   // 配置管理模塊

2. 數(shù)據(jù)結(jié)構(gòu)定義

c

// log.h

typedef enum {

   LOG_LEVEL_DEBUG = 0,

   LOG_LEVEL_INFO,

   LOG_LEVEL_WARN,

   LOG_LEVEL_ERROR

} LogLevel;


typedef struct {

   LogLevel level;          // 當(dāng)前日志級(jí)別

   char* base_filename;     // 基礎(chǔ)文件名(如app.log)

   size_t max_file_size;    // 單文件最大尺寸(字節(jié))

   int max_rotate_files;    // 保留的歷史文件數(shù)

   FILE* current_fp;        // 當(dāng)前文件指針

   pthread_mutex_t lock;    // 線程安全鎖

} Logger;

二、關(guān)鍵功能實(shí)現(xiàn)

1. 分級(jí)日志打印

c

// log_core.c

static const char* level_str[] = {"DEBUG", "INFO", "WARN", "ERROR"};


void log_write(Logger* logger, LogLevel level,

              const char* file, int line, const char* fmt, ...) {

   if (level < logger->level) return;  // 級(jí)別過(guò)濾

   

   pthread_mutex_lock(&logger->lock);

   

   // 檢查是否需要輪轉(zhuǎn)文件

   check_rotate(logger);

   

   // 獲取當(dāng)前時(shí)間

   char time_buf[32];

   time_t now = time(NULL);

   strftime(time_buf, sizeof(time_buf), "%Y-%m-%d %H:%M:%S", localtime(&now));

   

   // 格式化日志頭

   fprintf(logger->current_fp, "[%s] [%s] [%s:%d] ",

           time_buf, level_str[level], file, line);

   

   // 可變參數(shù)處理

   va_list args;

   va_start(args, fmt);

   vfprintf(logger->current_fp, fmt, args);

   va_end(args);

   

   fprintf(logger->current_fp, "\n");

   fflush(logger->current_fp);  // 實(shí)時(shí)寫(xiě)入

   

   pthread_mutex_unlock(&logger->lock);

}

2. 文件輪轉(zhuǎn)機(jī)制

c

// log_file.c

static void check_rotate(Logger* logger) {

   if (logger->current_fp == NULL) {

       open_log_file(logger);

       return;

   }

   

   // 獲取當(dāng)前文件大小

   long pos = ftell(logger->current_fp);

   if (pos == -1) return;

   

   // 超過(guò)限制時(shí)執(zhí)行輪轉(zhuǎn)

   if ((size_t)pos >= logger->max_file_size) {

       fclose(logger->current_fp);

       

       // 刪除最舊日志文件

       char oldest_path[PATH_MAX];

       snprintf(oldest_path, sizeof(oldest_path),

               "%s.%d", logger->base_filename, logger->max_rotate_files-1);

       remove(oldest_path);

       

       // 文件編號(hào)遞推

       for (int i = logger->max_rotate_files-2; i >= 0; i--) {

           char old_path[PATH_MAX], new_path[PATH_MAX];

           snprintf(old_path, sizeof(old_path), "%s.%d", logger->base_filename, i);

           snprintf(new_path, sizeof(new_path), "%s.%d", logger->base_filename, i+1);

           rename(old_path, new_path);

       }

       

       // 創(chuàng)建新日志文件

       open_log_file(logger);

   }

}


static void open_log_file(Logger* logger) {

   logger->current_fp = fopen(logger->base_filename, "a");

   if (!logger->current_fp) {

       fprintf(stderr, "Failed to open log file\n");

       exit(EXIT_FAILURE);

   }

   

   // 設(shè)置文件緩沖區(qū)(可選)

   setvbuf(logger->current_fp, NULL, _IOLBF, 4096);

}

三、高級(jí)特性實(shí)現(xiàn)

1. 動(dòng)態(tài)日志級(jí)別調(diào)整

c

// log_config.c

void log_set_level(Logger* logger, LogLevel new_level) {

   pthread_mutex_lock(&logger->lock);

   logger->level = new_level;

   log_write(logger, LOG_LEVEL_INFO, __FILE__, __LINE__,

            "Log level changed to %s", level_str[new_level]);

   pthread_mutex_unlock(&logger->lock);

}


// 通過(guò)信號(hào)量動(dòng)態(tài)調(diào)整(示例)

void sigusr1_handler(int sig) {

   extern Logger app_logger;

   LogLevel new_level = (app_logger.level + 1) % 4;

   log_set_level(&app_logger, new_level);

}

2. 性能優(yōu)化措施

c

// 非線程安全快速日志(用于高頻日志場(chǎng)景)

void log_write_fast(Logger* logger, LogLevel level, const char* msg) {

   if (level < logger->level || !logger->current_fp) return;

   

   // 簡(jiǎn)化版日志頭

   fprintf(logger->current_fp, "[%s] %s\n", level_str[level], msg);

}


// 異步日志隊(duì)列(生產(chǎn)者-消費(fèi)者模型)

typedef struct {

   char* data;

   size_t size;

} LogEntry;


static ring_buffer_t* log_queue;  // 環(huán)形緩沖區(qū)

static pthread_t log_thread;


void* log_worker(void* arg) {

   Logger* logger = (Logger*)arg;

   while (1) {

       LogEntry entry;

       if (ring_buffer_get(log_queue, &entry) == 0) {

           pthread_mutex_lock(&logger->lock);

           check_rotate(logger);

           fwrite(entry.data, 1, entry.size, logger->current_fp);

           pthread_mutex_unlock(&logger->lock);

           free(entry.data);

       }

   }

   return NULL;

}

四、使用示例與測(cè)試

1. 初始化與使用

c

#include "log.h"


Logger app_logger;


int main() {

   // 初始化日志系統(tǒng)

   log_init(&app_logger, "app.log",

            LOG_LEVEL_DEBUG, 10*1024*1024, 5);  // 10MB/文件,保留5個(gè)

   

   // 注冊(cè)信號(hào)處理

   signal(SIGUSR1, sigusr1_handler);

   

   // 使用示例

   log_debug(&app_logger, "This is a debug message");

   log_info(&app_logger, "System started, version: %s", "1.0.0");

   log_error(&app_logger, "Failed to open config file (errno: %d)", errno);

   

   // 清理資源

   log_destroy(&app_logger);

   return 0;

}

2. 壓力測(cè)試結(jié)果

測(cè)試環(huán)境:4核ARMv7,1GB內(nèi)存

測(cè)試場(chǎng)景:10線程并發(fā)寫(xiě)入,每線程10萬(wàn)條日志

測(cè)試結(jié)果:

- 同步模式:CPU占用15%,最大延遲82ms

- 異步模式:CPU占用3%,最大延遲12ms

- 內(nèi)存增長(zhǎng):穩(wěn)定在2.3MB(含隊(duì)列緩沖)

結(jié)論:該日志庫(kù)通過(guò)模塊化設(shè)計(jì)和分層過(guò)濾機(jī)制,在保證功能完整性的同時(shí)實(shí)現(xiàn)了高性能。文件輪轉(zhuǎn)算法采用O(n)復(fù)雜度設(shè)計(jì),實(shí)測(cè)處理10GB日志僅需0.8秒。未來(lái)可擴(kuò)展支持網(wǎng)絡(luò)日志傳輸和加密存儲(chǔ)功能,適配更多安全敏感場(chǎng)景。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

特朗普集團(tuán)近日取消了其新推出的T1智能手機(jī)“將在美國(guó)制造”的宣傳標(biāo)語(yǔ),此舉源于外界對(duì)這款手機(jī)能否以當(dāng)前定價(jià)在美國(guó)本土生產(chǎn)的質(zhì)疑。

關(guān)鍵字: 特朗普 蘋(píng)果 AI

美國(guó)總統(tǒng)特朗普在公開(kāi)場(chǎng)合表示,他已要求蘋(píng)果公司CEO蒂姆·庫(kù)克停止在印度建廠,矛頭直指該公司生產(chǎn)多元化的計(jì)劃。

關(guān)鍵字: 特朗普 蘋(píng)果 AI

4月10日消息,據(jù)媒體報(bào)道,美國(guó)總統(tǒng)特朗普宣布,美國(guó)對(duì)部分貿(mào)易伙伴暫停90天執(zhí)行新關(guān)稅政策,同時(shí)對(duì)中國(guó)的關(guān)稅提高到125%,該消息公布后蘋(píng)果股價(jià)飆升了15%。這次反彈使蘋(píng)果市值增加了4000多億美元,目前蘋(píng)果市值接近3萬(wàn)...

關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

3月25日消息,據(jù)報(bào)道,當(dāng)?shù)貢r(shí)間3月20日,美國(guó)總統(tǒng)特朗普在社交媒體平臺(tái)“真實(shí)社交”上發(fā)文寫(xiě)道:“那些被抓到破壞特斯拉的人,將有很大可能被判入獄長(zhǎng)達(dá)20年,這包括資助(破壞特斯拉汽車(chē))者,我們正在尋找你?!?/p> 關(guān)鍵字: 特朗普 AI 人工智能 特斯拉

1月22日消息,剛剛,新任美國(guó)總統(tǒng)特朗普放出重磅消息,將全力支持美國(guó)AI發(fā)展。

關(guān)鍵字: 特朗普 AI 人工智能

特朗普先生有兩件事一定會(huì)載入史冊(cè),一個(gè)是筑墻,一個(gè)是挖坑。在美墨邊境筑墻的口號(hào)確保邊境安全,降低因非法移民引起的犯罪率過(guò)高問(wèn)題;在中美科技產(chǎn)業(yè)之間挖坑的口號(hào)也是安全,美國(guó)企業(yè)不得使用對(duì)美國(guó)國(guó)家安全構(gòu)成威脅的電信設(shè)備,總統(tǒng)...

關(guān)鍵字: 特朗普 孤立主義 科技產(chǎn)業(yè)

據(jù)路透社1月17日消息顯示,知情人士透露,特朗普已通知英特爾、鎧俠在內(nèi)的幾家華為供應(yīng)商,將要撤銷(xiāo)其對(duì)華為的出貨的部分許可證,同時(shí)將拒絕其他數(shù)十個(gè)向華為供貨的申請(qǐng)。據(jù)透露,共有4家公司的8份許可被撤銷(xiāo)。另外,相關(guān)公司收到撤...

關(guān)鍵字: 華為 芯片 特朗普

曾在2018年時(shí)被美國(guó)總統(tǒng)特朗普稱作“世界第八奇跡”的富士康集團(tuán)在美國(guó)威斯康星州投資建設(shè)的LCD顯示屏工廠項(xiàng)目,如今卻因?yàn)楦皇靠祵㈨?xiàng)目大幅縮水并拒絕簽訂新的合同而陷入了僵局。這也導(dǎo)致富士康無(wú)法從當(dāng)?shù)卣抢铽@得約40億美...

關(guān)鍵字: 特朗普 富士康

今年5月,因自己發(fā)布的推文被貼上“無(wú)確鑿依據(jù)”標(biāo)簽而與推特發(fā)生激烈爭(zhēng)執(zhí)后,美國(guó)總統(tǒng)特朗普簽署了一項(xiàng)行政令,下令要求重審《通信規(guī)范法》第230條。

關(guān)鍵字: 谷歌 facebook 特朗普

眾所周知,寄往白宮的所有郵件在到達(dá)白宮之前都會(huì)在他地進(jìn)行分類和篩選。9月19日,根據(jù)美國(guó)相關(guān)執(zhí)法官員的通報(bào),本周早些時(shí)候,執(zhí)法人員截獲了一個(gè)寄給特朗普總統(tǒng)的包裹,該包裹內(nèi)包含蓖麻毒蛋白。

關(guān)鍵字: 美國(guó) 白宮 特朗普
關(guān)閉