log4cplus使用(三)-日志重定向

本文讲述的是log4cplus日志输出到qt widget,封装了serverSocket。
   
log4cplus支持用户自定义输出设备,只需要继承自Appender,或者Appender子类,并实现append成员方法,然后在
log4cplus初始化成功之后,把自定义输出设备添加到logger中,当用户向logger中输出信息时,logger会遍历自身的所有输出设备,
并按输出设备上的指定格式输出信息。

log4cplus是线程安全的,因此在多线程下可以放心使用

在小工具编写的过程中,作者遇到了ESP
Crash问题,在网上了找了好久的资料,也没搞好,后来当然是解决了,原因:我的小工具是用vs2013写的,log4cplus库使用vs2010编
译的,后来用vs2013编译了下log4cplus,小工具一切正常;不过log4cplus自带的事例代码却开始crash了(vs2010下正
常),后来网上各种百度、谷歌,发现有的人说这是vs2013的bug,反正是最后也没解决。

小工具运行流程:启动小工具,开启接收远端连接线程W,这样不阻塞ui主线程,当接收线程收到远端连接时,开启收据接收子线程R,来和远端交互,每个线程
更新一个widget,当线程W关闭时,关闭掉所有由W创建的子线程R,然后关闭serverSocket。R线程接收的数据使用抛事件的方式传递给
widget,当然不是直接抛给widget,而是有一个专门处理事件的线程,接收各种不同的事件,然后通过信号槽,发送到指定窗口,窗口更新到界面上。

效果如图1所示

图1

主要的类说明:

1、工作者线程,监听消息事件
class MessageListening : public QThread

2、帮助工作者线程处理业务的对象,用户监听客户端的连接请求
class Work : public QObject
工作者线程
class WorkThread : public QThread

3、工作者线程,监听消息事件
class MessageListening : public QThread

4、服务器端线程,负责和客户端进行交互
class ClientThread : public log4cplus::thread::AbstractThread

5、小工具主窗口 负责接收并显示日志信息
class debugHelper : public QWidget

6、用户列表,显示当前连接的用户+默认+创建的用户
class CCUserListWidget : public QTreeWidget

7、自定义输出设备
class CCUIAppender : public ConsoleAppender

8、日志过滤数据源 负责提供给视图过滤后的数据,数据源来自QStandardItemModel
class CCSortFilterProxyModel : public QSortFilterProxyModel

9、日志窗口 针对每个用户new一个
class CCLogTableWidget : public QWidget

10、本地日志加载创建 用于比对多个不同来源的日志
class CCLogListWidget : public QWidget

时间: 2024-11-11 05:43:58

log4cplus使用(三)-日志重定向的相关文章

SecurityCRT输出日志重定向

使用CRT进行抓取log,因为工具本省缓冲区有限,导致,刷屏特别快,可能会错过一些log,可以对CRT的log进行增加输出源,或者说将输出到控制台的log再输出到本地文件中: 文件->点击(勾选)日志文件:这个选项代表打出到控制台的日志将会输出到日志文件中: 选项->会话选项->终端->日志文件:指定输出文件路径以及名称: 如此配置,就可以将log输出到指定的文件中了. SecurityCRT输出日志重定向,布布扣,bubuko.com

log日志重定向

1.重定向: 我们在使用NSLog(@"hahaha") 时,实质是将"hahaha"写入到一个系统默认位置的log文件中,然后控制台通过实时获取这个文件的内容进行显示打印信息. 但有时我们希望不需要链接xcode在手机上直接查看日志信息,这个时候我们就需要将log日志的位置调整到我们想要的指定位置. 好处: 这样调整的好处是我们可以自定义一个textview来读取log日志内容,通过某种方式触发(比如摇晃),来将实时的日志直接像是到手机上. 也可以通过后台接口上传

使用Log4Cplus+配置文件打印日志

开发环境:win7+VS2015 msvc14 版本:log4CPlus1.2.1 API参考:https://log4cplus.sourceforge.io/docs/html/index.html 前两天工作中使用到了Log4Cplus来记录程序日志,下面总结下通过配置文件来使用Log4Cplus库. 基本要求:日志文件按天命名,每天生成一个文件. 配置文件: log4cplus.rootLogger=ALL, LegendPrint_Run_LOG //指定append类型,因为我们这需

weblogic启动时日志重定向(nohup.out)

由于weblogic使用  nohup ./startWebLogic.sh &   启动时会将所有日志打印到nohup.out上,长此以往会导致该文件越来越大,不便于管理. 故下面介绍如何重定向该日志: 在startWebLogic.sh 或 startManagedWebLogic.sh文件中 #Start Derby# 这一行的上面增加WLS_REDIRECT_LOG重定向日志文件: WLS_REDIRECT_LOG="/weblogic/domain/base_domain/lo

使用System.out.printf()输出日志重定向到文件后显示混乱问题

写了一个小工具,使用System.out.printf()输出日志,以方便使用者查看,在终端显示没有问题,但重定向到文件就有问题了,会出现一些很奇怪的乱序现象. 上网查询资料,判断应该是跟重定向和Linux缓冲区有关,标准输出为行缓冲,文件为全缓冲,可以使用 stdbuf -oL [command] 来实现重定义缓冲区类型,于是将原先的启动脚本中的 nohup java ... & 改为 nohup stdbuf -oL ... & , 这样改完后用vim命令查看文件内容是正常的,但使用t

实现jul 日志重定向到 slf4j

需求背景 jul 指的是java.util.logging,是 java 内置的日志模块,目前流行的Java日志组件还包括 jcl(common-logging).slf4j/log4j/logback 等等 不同日志框架的定位和特性都存在差异,如 jcl.slf4j 提供的是日志门面(api)定义,log4j.logback则侧重于实现. 通常一个团队会采用统一的日志组件,slf4j 目前的受欢迎程度较高,其在易用性.可移植性方面都优于jul: 然而项目中采用的一些开源组件可能直接采用了jul

ios 将Log日志重定向输出到文件中保存

对于真机,日志没法保存,不好分析问题.所以有必要将日志保存到应用的Docunment目录下,并设置成共享文件,这样才能取出分析. 首先是日志输出,分为c的printf和标准的NSLog输出,printf会向标准输出(sedout)打印,而NSLog则是向标准出错(stderr),我们需要同时让他们都将日志打印到一个文件中. 例子: freopen("xx.log","a+",stdout); freopen("xx.log","a+&q

Log4Qt快速入门——Log4Qt日志输出重定向源码解析

Log4Qt快速入门--Log4Qt日志输出重定向源码解析 一.Appender简介 1.Appender简介 Appender是所有Appender的抽象类,是对记录日志形式的抽象.Log4Qt(Qt4版本)中Appender继承体系如下: 2.Appender接口 virtual Filter *filter() const = 0; virtual QString name() const = 0; virtual Layout *layout() const = 0; virtual b

log4cplus使用(二)-自定义日志等级

log4cplus支持用户自定义日志等级,操作也比较简单,使用之前贴如下宏定义 #define LOG4CPLUS_MACRO_CREASH_LOG_LEVEL(pred) LOG4CPLUS_UNLIKELY(pred) namespace log4cplus {  const LogLevel CREASH_LOG_LEVEL = 55000; } #define LOG4CPLUS_CREASH(logger, logEvent) LOG4CPLUS_MACRO_BODY(logger,