C/C++log日志库比较

事实上,在C的世界里面没有特别好的日志函数库(就像JAVA里面的的log4j,或者C++的log4cxx)。C程序员都喜欢用自己的轮子。printf就是个挺好的轮子,但没办法通过配置改变日志的格式或者输出文件。syslog是个系统级别的轮子,不过速度慢,而且功能比较单调。

尝试了几种C/C++ log库,简单记录如下:

1 log4j的衍生品


日志是应用软件中不可缺少的部分,Apache的开源项目Log4j是一个功能强大的日志组件,提供方便的日志记录,他有很多移植版(包括官方的和非官方的版本)

1.1 log4cxx


地址 http://logging.apache.org/log4cxx/

Log4cxx是开放源代码项目Apache Logging Service的子项目之一,是Java社区著名的log4j的c++移植版,用于为C++程序提供日志功能,以便开发者对目标程序进行调试和审计。

1.2Log4cpp


log4cpp是个基于LGPL的开源项目,移植自Java的日志处理跟踪项目log4j,并保持了API上的一致。其类似的支持库还包括Java(log4j),C++(log4cpp、log4cplus),C(log4c),python(log4p)等。
log4c ,

1.3log4c

log4c现已不再有人维护了。不是面向对象的,不支持流式log输入。有配置文件。最新版本(log4c-1.2.4.tar.gz)存在内存泄露。不建议使用。

1.4 log4cplus

地址 http://sourceforge.net/projects/log4cplus/

log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统.受Apache Software License保护。

作者是Tad E. Smith。log4cplus具有线程安全、灵活、以及多粒度控制的特点,通过将信息划分优先级使其可以面向程序调试、运行、测试、和维护等全生命周期; 你可以选择将信息输出到屏幕、文件、
NT event log、甚至是远程服务器;通过指定策略对日志进行定期备份等等。

2 google glog


Google glog是一个基于程序级记录日志信息的c++库,编程使用方式与c++的stream操作类似,例:

LOG(INFO) << “Found ” << num_cookies << ” cookies”;

LOG”宏为日志输出关键字,“INFO”为严重性程度。
主要支持功能:

1, 参数设置,以命令行参数的方式设置标志参数来控制日志记录行为;
2, 严重性分级,根据日志严重性分级记录日志;
3, 可有条件地记录日志信息;
4, 条件中止程序。丰富的条件判定宏,可预设程序终止条件;
5, 异常信号处理。程序异常情况,可自定义异常处理过程;
6, 支持debug功能。可只用于debug模式;
7, 自定义日志信息;
8, 线程安全日志记录方式;
9, 系统级日志记录;
10, google perror风格日志信息;
11, 精简日志字符串信息。

3 z-log


地址 https://github.com/HardySimpson/zlog

z-log是一个高性能、线程安全、灵活、概念清晰的纯C日志函数库。
难易编写

这里写图片描述

zlog有这些特性:

  • syslog分类模型,基于规则路由过滤,比log4j模型要正确高效,详见为什么log4j的概念模型是错误的。

  • 日志格式定制,类似于log4j的pattern layout

  • 多种输出,包括动态文件、静态文件、stdout、stderr、syslog、用户自定义输出函数

  • 运行时手动或自动刷新配置(同时保证安全)

  • 高性能,在我的笔记本上达到338’638条日志每秒, 大概是syslog(3)配合rsyslogd的1000倍速度

  • 高可靠性和速度之间的平衡,用户自定义多少条日志后fsync数据到硬盘

  • 用户自定义等级

  • 多线程和多进程环境下保证安全转档

  • 精确到微秒

  • 简单调用包装dzlog(一个程序默认只用一个分类)

  • MDC,线程键-值对的表,可以扩展用户自定义的字段

  • 自诊断,可以在运行时输出zlog自己的日志和配置状态

  • 不依赖其他库,只要是个POSIX系统就成(当然还要一个C99兼容的vsnprintf)

网友提供的其他版本,方便其他平台安装

auto tools版本: https://github.com/bmanojlovic/zlog
cmake版本:https://github.com/lisongmin/zlog
windows版本: https://github.com/lopsd07/WinZlog

4 spdlog


spdlog 是一个快速的 C++ 日志库,只包含头文件,兼容 C++11。

特性:

  • 非常快
  • 只包含头文件
  • 无需依赖第三方库
  • 支持跨平台 - Linux / Windows on 32/64 bits
  • 支持多线程
  • 可对日志文件进行循环输出
  • 可每日生成日志文件
  • 支持控制台日志输出
  • 可选的异步日志
  • 支持日志输出级别
  • 可自定义日志格式

5 c-log


c-log是一个稳定,高效,多线程安全,易用,简单的C/C++ 日志库,在github主页上有丰富的测试case,后续将会推迟直接输出到scribe等集中式日志收集中间件上,帮助用户更好的收集,分析日志

6 syslog-ng


syslog-ng作为syslog的替代工具,可以完全替代syslog的服务,并且通过定义规则,实现更好的过滤功能
的一个设计原则就是建立更好的消息过滤粒度。syslog-ng能够进行基于内容和优先权/facility的过滤。另一个设计原则是更容易进行不同防火墙网段的信息转发,它支持主机链,即使日志消息经过了许多计算机的转发,也可以找出原发主机地址和整个转发链。最后的一个设计原则就是尽量使配置文件强大和简洁。

7 轻量级日志EasyLogger


地址 :https://github.com/armink/EasyLogger

7.1 介绍


EasyLogger 是一款超轻量级(ROM<1.6K, RAM<0.3K)、高性能的 C/C++ 日志库,非常适合对资源敏感的软件项目,例如: IoT 产品、可穿戴设备、智能家居等等。相比 log4c、zlog 这些知名的 C/C++ 日志库, EasyLogger 的功能更加简单,提供给用户的接口更少,但上手会很快,更多实用功能支持以插件形式进行动态扩展。

7.2 主要特性


支持用户自定义输出方式(例如:终端、文件、数据库、串口、485、Flash…);
日志内容可包含级别、时间戳、线程信息、进程信息等;
日志输出被设计为线程安全的方式,并支持 异步输出 及 缓冲输出 模式;
支持多种操作系统(RT-Thread、UCOS、Linux、Windows…),也支持裸机平台;
日志支持 RAW格式 ;
支持按 标签 、 级别 、 关键词 进行动态过滤;
各级别日志支持不同颜色显示
扩展性强,支持以插件形式扩展新功能。
名词解释: 1、RAW格式:未经过格式化的原始日志。 2、标签:在软件中可以按照文件、模块、功能等方面,对需要打印的日志设定标签,实现日志分类。

以下是网络服务能力测试工具对应模块的实现方法和技术手段的C/C++代码示例: 1. 测试数据生成模块 测试数据生成模块可以使用随机数生成算法、数据模板生成算法等,以下是使用随机数生成算法的示例代码: ```c++ #include <cstdlib> #include <ctime> // 生成随机数 int rand_int(int min, int max) { static bool initialized = false; if (!initialized) { srand(time(NULL)); initialized = true; } return rand() % (max - min + 1) + min; } ``` 2. 测试执行控制模块 测试执行控制模块可以使用多线程技术、事件驱动技术等,以下是使用多线程技术的示例代码: ```c++ #include <thread> #include <vector> void test_worker(int thread_id) { // 执行测试任务 } // 启动并发测试 void start_concurrent_test(int thread_count) { std::vector<std::thread> threads; for (int i = 0; i < thread_count; i++) { threads.push_back(std::thread(test_worker, i)); } for (auto& t : threads) { t.join(); } } ``` 3. 测试结果收集模块 测试结果收集模块可以使用性能指标计算算法、性能指标统计算法等,以下是使用性能指标计算算法的示例代码: ```c++ #include <chrono> // 计算响应时间 long long calc_response_time(std::chrono::system_clock::time_point start_time, std::chrono::system_clock::time_point end_time) { std::chrono::duration<long long, std::micro> diff = end_time - start_time; return diff.count(); } ``` 4. 测试结果分析模块 测试结果分析模块可以使用数据分析算法、统计分析算法等,以下是使用统计分析算法的示例代码: ```c++ #include <algorithm> #include <vector> // 计算最大值 template<typename T> T calc_max(const std::vector<T>& data) { return *std::max_element(data.begin(), data.end()); } // 计算平均值 template<typename T> T calc_mean(const std::vector<T>& data) { T sum = std::accumulate(data.begin(), data.end(), 0); return sum / data.size(); } ``` 5. 网络通信模块 网络通信模块可以使用Socket编程接口、第三方网络等,以下是使用Socket编程接口的示例代码: ```c++ #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> // 建立TCP连接 int tcp_connect(const char* ip, int port) { int sockfd = socket(AF_INET, SOCK_STREAM, 0); if (sockfd < 0) { return -1; } struct sockaddr_in serv_addr; memset(&serv_addr, 0, sizeof(serv_addr)); serv_addr.sin_family = AF_INET; serv_addr.sin_addr.s_addr = inet_addr(ip); serv_addr.sin_port = htons(port); if (connect(sockfd, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) < 0) { return -1; } return sockfd; } ``` 6. 界面交互模块 界面交互模块可以使用命令行界面、图形界面等,以下是使用命令行界面的示例代码: ```c++ #include <iostream> // 输出测试结果 void output_test_result(const std::string& result) { std::cout << result << std::endl; } // 获取测试参数 void get_test_params(int& thread_count, int& test_duration) { std::cout << "请输入线程数:"; std::cin >> thread_count; std::cout << "请输入测试时间(秒):"; std::cin >> test_duration; } ``` 7. 其他组成部分 其他组成部分包括日志记录模块、配置文件管理模块、异常处理模块等,以下是日志记录模块的示例代码: ```c++ #include <fstream> #include <chrono> // 记录日志 void write_log(const std::string& message) { std::ofstream log_file("log.txt", std::ios::app); if (log_file.is_open()) { auto now = std::chrono::system_clock::now(); std::time_t now_time = std::chrono::system_clock::to_time_t(now); log_file << std::ctime(&now_time) << message << std::endl; log_file.close(); } } ``` 总之,在C/C++中实现网络服务能力测试工具的对应模块可以使用多种技术手段和算法,包括随机数生成算法、多线程技术、事件驱动技术、性能指标计算算法、数据分析算法、Socket编程接口等。通过合理选择和应用这些技术和算法,可以实现高效、准确的网络服务能力测试工具。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值