|
|
赶快注册并登录访问我们网站,呈现更多精彩内容!
您需要 登录 才可以下载或查看,没有帐号?注册加入
x
快速本地使用:' D2 D: D, I/ o/ y- e& M
1. 在Windows电脑上,我们推荐使用WM_COPYDATA消息进行日志传输,资源占用最少,速度最快。
% D- p% f- `: n4 | s$ r% _2. 如果您的应用程序已经具备UDP或TCP功能,可以直接通过原有的Socket将日志发送到本机的127...1。
) c6 A( P8 _. G$ Z& b) v3. 对于嵌入式系统的本地调试,您可以通过串口、USB或网口来进行日志传输。5 U/ o: @ |. R
& Z( v- B6 W- A0 W7 S. Y! F3 h便捷远程及云端使用:' e. H5 \) a9 T7 ]
1. 您可以在路由器中设置端口转发功能,将对应的端口转发到安装了CloudLog的电脑上。. k4 ~& N4 H2 w$ z. N
2. 为了方便获取到电脑所在的IP地址,我们建议使用动态域名系统(DDNS)服务。* ^, L& L6 a: M1 Q
3. 使用云控域名账号,在服务器上保存日志,您可以随时打开CloudLog回读所有未读过的日志。
' y# |- _4 m* b- O' y
% t6 W' _$ u; W" U2 Z' hCloudLog的日志元素介绍:
' A/ k6 f, r3 E- d+ b+ U x4 i1. 日志等级(Log Level,简写为LL)用于确认日志的重要性。% U4 Z( ]# Y+ G4 C; q i1 P4 b9 ?: P
2. 日期时间Tick(Date Time tick,简写为DT)用于确定日志生成的时刻。+ V- d' I$ s$ v: G5 X3 t
3. 应用名(App Name,简写为AN)用于确认日志的来源项目或进程。+ b. a/ f: v! L+ ^
4. 标签(Tag,简写为TA)用于按模块化区分日志。
' _1 I( }" f& t5 M# g. u5. 线程标识符(Thread Identity,简写为TI)用于区分多线程。
W7 S5 t( d/ V5 ]6. 文字内码(Text Code,简写为TC)用于实时调整当前的内码。
0 a7 [) o7 `2 c6 I+ |6 N% ~7. 日志文字(Log Text,简写为LT)可以使用任何内码进行记录。. ^, h# t# J0 W6 T. n% O/ b! D
8. 日志缓冲(Log Buffer,简写为LB)可以传送阵列缓冲。- {0 B+ Z. C- E' h1 |6 m& W
9. 计时功能可以根据前一条日志的tick,计算出精确到1微秒的用时。
i' `( h1 W2 G. T% l7 f' t9 O b' T4 U6 K7 \. z; f/ x
CloudLog的日志等级说明:( S$ V. J& y! O- o, [
1. Error级别表示严重的问题或软件执行功能错误,是最高等级的日志,无法屏蔽。1 b2 S+ s5 w' y5 H- t% t
2. Warn级别表示可能出现潜在错误的情况,当选择Error级别时,Warn级别的日志将不会显示。
2 ]; k; q/ k8 W$ y" @: X9 n3. Info级别强调应用程序运行过程中的一些重要信息。" \3 Z+ j) d: Y$ ~4 f2 @" p0 _( p; U
4. Debug级别仅在开发期间有用的调试消息,等级较低,在正式发布时一般不会出现。
0 M0 w1 j+ n! V, E* {5. Buffer阵列数值直接显示等级与Debug相同。2 L/ R7 r8 H& ^5 ]" {3 w
6. Fixer级别用于固定位置显示日志,这些日志不保存到log文件中。
0 k. |( A4 z- j! g; B0 x/ Z% E9 s6 ^
CloudLog的日志过滤器功能:
# ?* U- t: T3 l. n. K( P' Y1. 可以根据日志等级及各种组合来过滤日志记录。
" ?) w- i0 {( V2. 关键词可以高亮显示,以增强可读性,您可以自定义加大、加粗或指定专门的颜色进行高亮突出显示。- r- C( \& i1 d8 T0 m9 P8 r4 l }( J
3. 您可以指定关键词,使含有指定关键词的日志不显示。
& ^4 C) O, C0 {( P! b8 k4. 您也可以指定关键词,使含有指定关键词的日志显示。
E: c9 |# t2 k* o. V' M! F# j+ X5. 您还可以根据应用名中的关键词进行显示过滤。
9 Q! l" g" {0 j5 `: a3 F; q6. 同样地,您可以根据标签中的关键词进行显示过滤。/ i( h+ y" w- A8 b. o
9 O. I2 N% l3 Y5 T3 a% rCloudLog支持的键值对风格文字:
5 Z. ? ^! j1 _/ ~6 @1. 使用'&'分隔各个日志元素,每个元素由键值':'数值组成。
* v+ ?( F2 Y8 z8 M2. 日期时间Tick、日志文字及日志缓冲的数值使用Base64编码。
8 \5 Y' ~( M6 F e- V3. 应用名、标签及线程标识符一般只使用数字或字母。. V- n! ]; C" u/ T) \
4. 日期时间可以选择是否传送,可以是2字节的毫秒(ms)、3字节的微秒(us)或8字节的全部时间。
' x' y9 v3 {1 a. Y3 c0 q% f5 A5. 一个简单的示例:"hello"日志可以表示为:ll:D&/aGVsbG8=2 N- H2 b# L, h2 |8 r/ e
& q) l3 G' }8 O1 O$ d0 P# ~# { M+ {CloudLog支持的简易风格文字:
) Z1 \- {4 f0 }/ Q$ L; e1. 使用空格分隔各个日志元素,请勿调换元素的顺序。% g: r7 r% u0 B3 d3 n' @8 `
2. 最少包含日志等级(LL)空格及日志文字(LT)。
8 D8 e7 J$ v7 @: ?& O3. LL+LT+文字,LT表示4位数的毫秒tick,范围从000到9999,最大可以表示10秒的时间间隔。) D( u% k; ]% t0 Q0 U. V
4. LL+LT+TAG+文字,TAG标签用于按模块化区分日志,一般使用字母表示。. E! }- B; v0 t) f* i
5. LL+LT+TAG+TI+文字,TI为-9的数字,表示线程标识符。
& p3 r5 q+ d p% P6. LL+LT+TAG+TI+TC+文字,TC为G=GBK内码或U=UTF-8内码。* a2 N% a0 R4 k
/ H) ?$ _' C6 j2 ~; ~' _8 _% q使用开源库CloudLog的方法:! L: a- |. C2 q5 N0 _: V/ J% ?
1. 直接从 https://gitee.com/hsav20/CloudLog.git 克隆整个仓库。
! o! P0 W; C a Q2. 将CloudLog.c和CloudLog.h文件添加到您的项目中。- K) {" \) H; a4 u% r6 E3 D
3. 在对应的平台目录(如PlatformWindows)中找到一个最接近的模板文件FwbConf.h,并将其复制到您的项目中。: K3 `6 V8 v2 N$ [) |3 U
4. 根据您的实际使用环境,修改FwbConf.h中的配置信息。
% e+ y2 p1 C' T; f9 `2 {/ d5. 参考PlatformWindows目录下的main.c文件,您可以了解如何输出不同类型的日志。 |
|