|
|
赶快注册并登录访问我们网站,呈现更多精彩内容!
您需要 登录 才可以下载或查看,没有帐号?注册加入
x
快速本地使用:
V9 I( @' C5 G2 H/ x1. 在Windows电脑上,我们推荐使用WM_COPYDATA消息进行日志传输,资源占用最少,速度最快。8 Y$ u, n1 G0 b. O
2. 如果您的应用程序已经具备UDP或TCP功能,可以直接通过原有的Socket将日志发送到本机的127...1。
' j6 h# l/ W) ?7 m+ r( O3. 对于嵌入式系统的本地调试,您可以通过串口、USB或网口来进行日志传输。7 E1 v8 F) ?" a% ^5 C) q$ C
$ y. L% M; m3 y+ _便捷远程及云端使用:
% |+ q# |- c! w: t9 B1. 您可以在路由器中设置端口转发功能,将对应的端口转发到安装了CloudLog的电脑上。
+ ?! N& v, o) t; g% y2. 为了方便获取到电脑所在的IP地址,我们建议使用动态域名系统(DDNS)服务。; n; K3 {0 z- k7 C
3. 使用云控域名账号,在服务器上保存日志,您可以随时打开CloudLog回读所有未读过的日志。2 q. C) y! a4 k1 v: |. Q
# K+ q# S% D6 |$ [. I2 R4 [CloudLog的日志元素介绍:
1 d9 `1 c2 l6 N4 J8 h& x1. 日志等级(Log Level,简写为LL)用于确认日志的重要性。
) ^( ^2 u- l& u, U! K( D2. 日期时间Tick(Date Time tick,简写为DT)用于确定日志生成的时刻。
1 A: }1 g6 ~- M- v% M3 S/ ]: C3. 应用名(App Name,简写为AN)用于确认日志的来源项目或进程。4 S/ Z7 I0 R! o. ]1 H' O8 P
4. 标签(Tag,简写为TA)用于按模块化区分日志。4 G3 T. b6 q9 p# c9 P+ C+ i
5. 线程标识符(Thread Identity,简写为TI)用于区分多线程。5 _% B, \5 N- u' A- _& o. n" s8 |
6. 文字内码(Text Code,简写为TC)用于实时调整当前的内码。3 U9 V [0 _$ @) k0 P* F
7. 日志文字(Log Text,简写为LT)可以使用任何内码进行记录。
$ L; S \( W+ ?, v1 W7 Q' z8. 日志缓冲(Log Buffer,简写为LB)可以传送阵列缓冲。: G( v0 T4 G) z2 }' P1 C
9. 计时功能可以根据前一条日志的tick,计算出精确到1微秒的用时。' H7 r7 Q8 c+ ^; o+ ]
9 N% G5 e- S$ K- s/ D3 `CloudLog的日志等级说明:9 F1 T2 V. c e, O5 T1 L, h
1. Error级别表示严重的问题或软件执行功能错误,是最高等级的日志,无法屏蔽。
* M' t) P7 e6 g% P+ M D- j1 m6 Q2. Warn级别表示可能出现潜在错误的情况,当选择Error级别时,Warn级别的日志将不会显示。- ~/ ?9 l* ^5 l
3. Info级别强调应用程序运行过程中的一些重要信息。
2 ]+ P$ ?+ H' n7 z4. Debug级别仅在开发期间有用的调试消息,等级较低,在正式发布时一般不会出现。) C( F3 M- C9 e6 V& @1 k
5. Buffer阵列数值直接显示等级与Debug相同。3 t& P2 a9 g( g9 R; L
6. Fixer级别用于固定位置显示日志,这些日志不保存到log文件中。/ {& [6 ~! R/ |
% d9 f) P* G- a4 }* ]6 y
CloudLog的日志过滤器功能:2 o) a% T3 D3 y# I& J4 r
1. 可以根据日志等级及各种组合来过滤日志记录。1 Q/ D3 ?0 y( V B0 u7 H
2. 关键词可以高亮显示,以增强可读性,您可以自定义加大、加粗或指定专门的颜色进行高亮突出显示。
; @. W2 E& V! q3. 您可以指定关键词,使含有指定关键词的日志不显示。
) w5 [' T m/ k- O4 i; ~4. 您也可以指定关键词,使含有指定关键词的日志显示。
5 h- j a% _5 _/ J! ?5. 您还可以根据应用名中的关键词进行显示过滤。
+ u# b: M+ z9 c* T/ W6 n6. 同样地,您可以根据标签中的关键词进行显示过滤。
, u9 y- O U4 H: {
- O: ^4 I0 Z o# J' f! \' s: OCloudLog支持的键值对风格文字:3 W, k; R l" C+ A S$ p
1. 使用'&'分隔各个日志元素,每个元素由键值':'数值组成。
; F/ |- h3 p V2. 日期时间Tick、日志文字及日志缓冲的数值使用Base64编码。
: {! b( C6 h4 |$ D3. 应用名、标签及线程标识符一般只使用数字或字母。) D( k- ^& |5 e/ L' c
4. 日期时间可以选择是否传送,可以是2字节的毫秒(ms)、3字节的微秒(us)或8字节的全部时间。0 \& \) |/ y1 F: f: y5 F4 q
5. 一个简单的示例:"hello"日志可以表示为:ll:D&/aGVsbG8=" X x# v9 M$ i+ T& {
& L/ p0 u# T# [( m, U
CloudLog支持的简易风格文字:
9 C4 ~" E0 D$ c+ L$ F1. 使用空格分隔各个日志元素,请勿调换元素的顺序。: m0 v( e9 x- _. w1 W
2. 最少包含日志等级(LL)空格及日志文字(LT)。) Q- p3 o2 \* e5 H: r: A* w
3. LL+LT+文字,LT表示4位数的毫秒tick,范围从000到9999,最大可以表示10秒的时间间隔。
) I3 `7 S; |4 B8 ~, p8 Q- J4. LL+LT+TAG+文字,TAG标签用于按模块化区分日志,一般使用字母表示。
/ e* v& l+ q! t6 p3 W) f5. LL+LT+TAG+TI+文字,TI为-9的数字,表示线程标识符。
6 {# `6 I, i; z6. LL+LT+TAG+TI+TC+文字,TC为G=GBK内码或U=UTF-8内码。
% e% C* O8 s$ ~' l# C! U. ]) a" j0 W
使用开源库CloudLog的方法:
- q8 _% X8 G$ c3 M7 e7 I# b. M1. 直接从 https://gitee.com/hsav20/CloudLog.git 克隆整个仓库。0 o' Q5 I6 t1 Q! @8 X, ?
2. 将CloudLog.c和CloudLog.h文件添加到您的项目中。6 u- m% I9 n8 B. ]; g1 |0 ]
3. 在对应的平台目录(如PlatformWindows)中找到一个最接近的模板文件FwbConf.h,并将其复制到您的项目中。
! T! M; `4 A+ g; o( T: c4. 根据您的实际使用环境,修改FwbConf.h中的配置信息。: |7 r3 \ n" Q1 H
5. 参考PlatformWindows目录下的main.c文件,您可以了解如何输出不同类型的日志。 |
|