OpenWrt 系统日志之logread

前言

刚开始接触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_LOCKING
		int i;
		int len_first_part;
		int len_total = len_total; /* for gcc */
		char *copy = copy; /* for gcc */
#endif
		if (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_LOCKING
		len_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;
#else
		while (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_LOCKING
		for (i = 0; i < len_total; i += strlen(copy + i) + 1) {
			fputs(copy + i, stdout);
		}
		free(copy);
#endif
		fflush_all();

http://man.cx/syslogd(8)

OpenWrt 系统日志之logread

时间: 2024-09-28 21:33:40

OpenWrt 系统日志之logread的相关文章

公寓上网新认证方式破解研究

[分析客户端文件]客户端有三个文件,一个.exe,一个.pid,一个Skin.7z.最后一个文件里都是皮肤.前两个文件的名字,以及第二个文件的内容都是一串相同的字符串,还不知道有什么意义. [分析日志]客户端提供了查看日志功能,这给破解带来了很大方便,软件运行的大致流程日志中一目了然,一些有用的信息也在此暴露:模块“本机网络配置信息”,检查了本机网卡和活动链接信息,其中注意到一句:“是否支持802.1x:Yes”.说明这套系统很可能会支持802.1x认证协议.这应该不是好消息.模块“多路路由管理

OpenWRT 一些好玩的软件

[email protected]:/tmp/opkg-lists# opkg--help opkg:unrecognized option `--help' opkgmust have one sub-command argument usage:opkg [options...] sub-command [arguments...] wheresub-command is one of: PackageManipulation: update 升级 Update list ofavailab

Openwrt之断线邮件报告

为什么断线了还能发邮件报告呢 因为我用的是多wan配置,4个接口都断线的可能性不大 负载均衡用的是MWAN3这个软件搞得确实不错,本身就自带事件报告的脚本了,因此要实现断线报告也很简单,把发邮件的命令加到对应位置就可以了 默认的脚本是这样的 #!/bin/sh # to enable this script uncomment the case loop at the bottom # to report mwan status on interface hotplug ifup/ifdown

智能小车24:openwrt的入门体验

openwrt是一个开源的linux系统.在硬改烧写路由器flash时,我非常惊讶于他的精简,4m就够了,16m就可以安装好些软件了.下面我介绍的是用的16m的,主要是luci的功能.这个控制台封装了主要的功能,我带大家来看一下这16m都能干些什么? 1.登录与权限管理 2.状态(统计信息) 总览:除了图里的硬件信息.内存,还有网络状态.DHCP分配.无线.已连接站点这些信息. 防火墙:可以看下流量情况,但是里面的链表和策略我看不懂,有专业的同学帮解释下. 路由表:有arp信息,arp就是mac

OpenWRT嵌入式Linux故障排除一例

跟大数据没关系,只是帮朋友忙排了个错记录一下. 以前关系很不错的同事,目前在企业级wifi领域创业,采购了我们的大数据服务,正在给他做平台的搭建和调试.然后这几天他这个CEO在调试路由器的时候遇到一些问题,在搞大数据的同时捎带手解决了一下他这个问题. OpenWRT,嵌入式Linux,主要用在MIPS或ARM设备上.路由器和wifi设备很多会采用这个系统,特点是轻巧. Coova-Chilli,在openwrt下的接入访问控制器,提供认证网关,可以使用radius或http来做接入计费等工作.

openwrt+openvpn配置

Server配置端: 一.安装openvpn Yum install –y lzo Yum install –y openvpn Wget https://github.com/OpenVPN/easy-rsa 1.unzipeasy-rsa-master.zip 2.cp easy-rsa-master/etc/openvpn/easy-rsa 3.cd/etc/openvpn/easy-rsa/easyrsa3/ 4.cp vars.example vars 5.vi vars 修改配置文件

Openwrt 路由器挂载摄像头教程

一.准备工作 首先就是要有一个刷了openwrt的路由器,固伯里至少包括下面两个摄像头相关模块 kmod-video-core, kmod-video-uvc 以及mjpeg-streamer软件,一个免驱并支持MJPEG输出的摄像头,本人使用HD5000,建议使用HD3000,差别不大 二.测试摄像头 将摄像头插到路由器上,然后SSH到路由器上,执行logread命令,会打印出路由器开机后的的终端log.在里面寻找 "usbcore:registered new interface drive

编译Openwrt的log

Openwrt配置: Target System (Ralink RT288x/RT3xxx) ---> Subtarget (MT7688 based boards) ---> Target Profile (LinkIt7688) ---> ---------------------------------------------------------------------------------------------------------------------------

OpenWrt学习目标

最近在研究OpenWrt,总感觉这一看一点那也了解一点,没有目的,也没有重心. 这里,给自己拟定一个目标,就朝着这个目标去学. 目标:在OpenWrt上开发服务器软件,该软件可以通过LuCI进行控制,并能提供网络接口,使用户可以通过手机对其进行操控. 要掌握的技能点: 掌握OpenWrt的裁剪,熟悉裁剪编译的原理.掌握基本的系统配置技能. 能编在OpenWrt上运行的程序.并能在OpenWrt上通过gdb进行调试.(重点) 掌握uhttpd的配置,与LuCI的工作原理.能根据需求设计网页界面.使