OpenWrt 系统日志之logread
来源:互联网 发布:如何成为程序员 编辑:程序博客网 时间:2024/06/01 09:43
前言
刚开始接触OpenWrt的时候,根本不知道如何调试各个进程,我之前从事IP Camera开发可能也局限了我的知识面,认为系统就改是那个样子。
其实不然,就像Linux发行版那样,他们都有各自都管理系统,同一个的消息通知系统,dbus和ubus这些。系统调试也是一样dmesg, 现在还接触到了logread。
初探
logread是在调试luci的时候用到的,极其方便,对于不太了解OpenWrt系统构成对人尤甚。
这个需要写进程对人对syslogd提供支持,否则说来知识惘然,我们需要做系统,需要做好对系统,就需要油完善对日志管理,精简无冗余对才是最有用的,这是我们使用其的目的。废话不多说,直接看卡logread的组成吧。
在busybox中实现了syslogd 和 logread.
syslogd用来记录log, logged则用来读取log.
logread的代码很简洁,主要实现过程是:连接共享内存->信号量加锁->读取共享内存中的信息并输出->信号量解锁。
连接共享内存
<span style="white-space:pre"></span>log_shmid = shmget(KEY_ID, 0, 0);if (log_shmid == -1)bb_perror_msg_and_die("can't %s syslogd buffer", "find");/* Attach shared memory to our char* */shbuf = shmat(log_shmid, NULL, SHM_RDONLY);if (shbuf == NULL)bb_perror_msg_and_die("can't %s syslogd buffer", "access");log_semid = semget(KEY_ID, 0, 0);if (log_semid == -1)error_exit("can't get access to semaphores for syslogd buffer");
信号量加锁
<span style="white-space:pre"></span>if (semop(log_semid, SMrdn, 2) == -1)error_exit("semop[SMrdn]");
读取共享内存中的信息并输出
/* Suppose atomic memory read *//* Max possible value for tail is shbuf->size - 1 */cur = shbuf->tail;/* Loop for logread -f, one pass if there was no -f */do {unsigned shbuf_size;unsigned shbuf_tail;const char *shbuf_data;#if ENABLE_FEATURE_LOGREAD_REDUCED_LOCKINGint i;int len_first_part;int len_total = len_total; /* for gcc */char *copy = copy; /* for gcc */#endifif (semop(log_semid, SMrdn, 2) == -1)error_exit("semop[SMrdn]");/* Copy the info, helps gcc to realize that it doesn't change */shbuf_size = shbuf->size;shbuf_tail = shbuf->tail;shbuf_data = shbuf->data; /* pointer! */if (DEBUG)printf("cur:%u tail:%u size:%u\n",cur, shbuf_tail, shbuf_size);if (!follow) {/* advance to oldest complete message *//* find NUL */cur += strlen(shbuf_data + cur);if (cur >= shbuf_size) { /* last byte in buffer? */cur = strnlen(shbuf_data, shbuf_tail);if (cur == shbuf_tail)goto unlock; /* no complete messages */}/* advance to first byte of the message */cur++;if (cur >= shbuf_size) /* last byte in buffer? */cur = 0;} else { /* logread -f */if (cur == shbuf_tail) {sem_up(log_semid);fflush_all();sleep(1); /* TODO: replace me with a sleep_on */continue;}}/* Read from cur to tail */#if ENABLE_FEATURE_LOGREAD_REDUCED_LOCKINGlen_first_part = len_total = shbuf_tail - cur;if (len_total < 0) {/* message wraps: *//* [SECOND PART.........FIRST PART] *//* ^data ^tail ^cur ^size */len_total += shbuf_size;}copy = xmalloc(len_total + 1);if (len_first_part < 0) {/* message wraps (see above) */len_first_part = shbuf_size - cur;memcpy(copy + len_first_part, shbuf_data, shbuf_tail);}memcpy(copy, shbuf_data + cur, len_first_part);copy[len_total] = '\0';cur = shbuf_tail;#elsewhile (cur != shbuf_tail) {fputs(shbuf_data + cur, stdout);cur += strlen(shbuf_data + cur) + 1;if (cur >= shbuf_size)cur = 0;}#endif
信号量解锁
unlock:/* release the lock on the log chain */sem_up(log_semid);#if ENABLE_FEATURE_LOGREAD_REDUCED_LOCKINGfor (i = 0; i < len_total; i += strlen(copy + i) + 1) {fputs(copy + i, stdout);}free(copy);#endiffflush_all();
http://man.cx/syslogd(8)
1 0
- OpenWrt 系统日志之logread
- 《转》OpenWrt 系统日志之logread
- 读取系统日志 logread
- OPENWRT 打印log消息到logread
- OpenWrt系统交换机之swconfig
- OpenWrt系统定制之base-files研究
- OpenWrt系统定制之base-files研究
- OpenWrt源码分析之编译系统
- Poco 日志 之 系统日志
- SQL SERVER数据库复制中出现logread代理失败的错误日志获取及分析办法
- Linux之日志系统
- Linux之日志系统
- Linux系统之系统日志
- openwrt编译日志
- openwrt日志查看、输出
- 日志系统之Flume日志收集
- 日志系统之Flume日志收集
- OpenWrt系统定制之base-files研究[转载]
- EXPORT_SYMBOL解析
- 函数配接器
- ERP 战场上的 SAP 与 Oracle
- Big Event in HDU
- 有好事者为windows批处理添加函数
- OpenWrt 系统日志之logread
- HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)
- hud1598 find the mostcomfortable road最小生成树 暴力枚举
- linux下mysql的root密码忘记解决方
- 赵作海案
- pyunit扩展:数据驱动测试(Data Driven Test)
- win7防火墙入站规则
- uva 729(全排列)
- 坑 - NES模拟器(1) - 读 ROM