NS3-logging 日志模块的使用
2017-03-01 15:56
429 查看
NS3-logging 日志模块的使用
NS3的消息日志功能可以用来监控或调试仿真程序执行的过程。日志输出可以在main()函数里通过相关程序来启用,也可以通过NS_LOG环境变量来使能。NS3提供了一个可供选择的、多级别的方法来记录日志。日志可以完全被禁用,或仅对某个部分组件可用,或全局可用。NS3还提供了不同详尽程度的日志级别供选。NS-3日志模块提供了直观的、相对简单的使用方法来帮助用户获得仿真过程的所需信息。日志应当作为快速获得你的脚本和模型的调试信息、警告信息、错误信息、或是其他信息的首要选择。
在现有的系统中,有7个详尽程度递增的日志级别,他们分别是:
NS_LOG_ERROR — 记录错误信息;
NS_LOG_WARN — 记录警告信息;
NS_LOG_DEBUG — 记录相对不常见的调试信息;
NS_LOG_INFO — 记录程序进展信息;
NS_LOG_FUNCTION — 记录描述每个调用函数信息;
NS_LOG_LOGIC – 记录一个函数内描述逻辑流程的信息;
NS_LOG_ALL — 记录所有信息.
每一个级别能够被单独地被调用或逐级递增地被调用,从上到下,级别依次增高。当我们使用一个日志级别标志时,我们实际上打开了这个日志级别和比它低的所有级别。比如,如果我们打开的日志级别是NS_LOG_INFO,那么我们我们就可以得到程序进展信息、调试信息、警告信息以及错误信息。
下面简单介绍logging在程序中的使用:
NS_LOG_COMPONENT_DEFINE (“FirstScriptExample”); // 定义一个日志组件,常见于程序开头部分。LogComponentEnable(“UdpEchoClientApplication”, LOG_LEVEL_INFO); // 对UdpEchoClientApplication组件启用日志,日志级别设置为LOG_LEVEL_INFO。
下面简单介绍logging在shell中配置环境时的使用:
export NS_LOG=UdpEchoClientApplication=level_all在不改变脚本或重新编译的情况下,通过设置NS_LOG环境变量来增加日志级别。环境变量NS_LOG设置为:UdpEchoClientApplication=level_all,等号左边是我们想要设置日志级别的组件的名字,等号右边是我们想要使用的日志级别。这样就为之后的程序运行打开所有的调试信息级别。
export ‘NS_LOG=UdpEchoClientApplication=level_all|prefix_func’
通过在NS_LOG环境变量中设置prefix_func级别来进一步查看某条信息来自哪个函数或程序。这样设置,你就可以看到每条日志都有产生此条日志的组件名做前缀了。
注意:这里引号是必须的,因为我们用的竖线表示或操作,而在Unix中竖线表示管道连接。
export ‘NS_LOG=UdpEchoClientApplication=level_all|prefix_func:
UdpEchoServerApplication=level_all|prefix_func’
通过在NS_LOG环境变量中键入一个单冒号隔开的组件列表来启用回显服务器应用组件。
注意:单冒号后不能有换行符,此处仅仅只是为了编排格式。
export ‘NS_LOG=UdpEchoClientApplication=level_all|prefix_func|prefix_time:
UdpEchoServerApplication=level_all|prefix_func|prefix_time’
通过使用prefix_time位来显示日志生成的仿真时间。
export ‘NS_LOG=*=level_all|prefix_func|prefix_time’
上面的星号是日志组件通配符,将打开在仿真过程中使用的所有组件的日志功能。使用下面的命令可以把产生的信息导入一个文件中:
./waf –run scratch/myfirst > log.out 2>&1.
export NS_LOG=
清除NS_LOG环境变量来关掉我们之前启用的日志文件。
export NS_LOG=FirstScriptExample=info
对于FirstScriptExample这个程序,只显示NS_LOG_INFO级别的日志。
关于NS3的logging功能,Tutorial的作者是这样说的:
I personally use this extremely verbose version of logging when I am presented with a problem and I have no idea where things are going wrong. I can follow the progress of the code quite easily without having to set breakpoints and step through code in a debugger. I can just edit up the output in my favorite editor and search around for things I expect, and see things happening that I don’t expect. When I have a general idea about what is going wrong, I transition into a debugger for a fine-grained examination of the problem. This kind of output can be especially useful when your script does something completely unexpected. If you are stepping using a debugger you may miss an unexpected excursion completely. Logging the excursion makes it quickly visible.[b]关于NS3 logging的详细内容,请参考:[/b]
ns-3-tutorial
ns-3-manual
相关文章推荐
- python —— 使用logging模块简单实现日志系统
- Python中使用logging模块打印log日志详解
- python2.7使用logging模块记日志,中文记入后乱码解决办法
- python标准日志模块logging使用
- Python 日志模块logging使用总结
- python的日志logging模块使用总结
- python标准日志模块logging的使用方法
- Python自带的日志模块logging的使用
- python 日志模块logging学习与使用(日志分割)
- NS3 Logging Module 日志模块
- python标准日志模块logging的使用方法
- python的日志logging模块使用总结
- 使用python中logging模块记录日志
- 详解Python中logging日志模块在多进程环境下的使用
- python标准日志模块logging的使用方法
- Python 日志记录模块logging的使用
- 4.Python记录日志logging模块的使用
- Python 中 logging 日志模块在多进程环境下的使用
- Python 中 logging 日志模块在多进程环境下的使用
- logging模块使用TCP/UDP发送纯日志内容