shell重定向调试信息
shell重定向调试信息
**************************************************************************************************************************************
作 者:fulinux
转载声明:http://blog.csdn.net/fulinus/article/details/29912333
**************************************************************************************************************************************
背景:移植wifi时,想实现启动后就能通过wifi上网,主要是通过脚本实现。开机启动时运行/etc/inittab脚本, 再调用/etc/init.d/rcS脚本,rcS脚本会依次运行/etc/init.d/文件夹下以Sxx开头的脚本文件,当中S01_network脚本文件是我们须要用到的。S01_network脚本部分内容例如以下:
#!/bin/sh
# FILE:/etc/init.d/S01_network
。。 。 if [ -d /sys/class/net/$DEVICE/ ] ; then
/apps/tools/ifup-wlan $i
route del default dev eth0
route add default gw 192.168.1.1
fi
。。。
S01_network脚本会调用/apps/tools/ifup-wlan脚本。
ifup-wlan脚本部分内容例如以下:
#!/bin/sh
# FILE:/usr/sbin/ifup-wlan0
。。 。
#Start wpa_supplicant to work now
mkdir -p /var/run/wpa_supplicant
/apps/tools/wpa_supplicant -B -Dwext -i$DEVICE -c${network_cfg_dir}/wpa_supplicant.conf
。 。 。
能够说上面全部脚本都没有错,由于我直接运行rcS脚本后会正常运行后面的全部脚本,运行后正常连接wifi路由器,例如以下:
[root@TQ2440 /etc/init.d]#iwconfig wlan0
wlan0 IEEE 802.11bg ESSID:"fulinus"
Mode:Managed Frequency:2.437 GHz Access Point: 94:0C:6D:4F:BD:C8
Bit Rate=1 Mb/s Tx-Power=20 dBm
Retry long limit:7 RTS thr:off Fragment thr:off
Encryption key:off
Power Management:on
Link Quality=70/70 Signal level=-21 dBm
Rx invalid nwid:0 Rx invalid crypt:0 Rx invalid frag:0
Tx excessive retries:0 Invalid misc:0 Missed beacon:0
可是却有一个问题。开机并不能实现wifi上网。启动后我发现根本没有连上wifi路由器。例如以下:
[root@TQ2440 ~]#iwconfig wlan0
wlan0 IEEE 802.11bg ESSID:off/any
Mode:Managed Access Point: Not-Associated Tx-Power=20 dBm
Retry long limit:7 RTS thr:off Fragment thr:off
Encryption key:off
Power Management:on
这就非常奇怪了。问题不好找。于是在郭工的意见下我開始通过重定向打印脚本的调试信息。
第一步。定位S01_network脚本。看看问题是不是在这里,于是我在S01_network脚本開始位置和结束位置增加例如以下设置:
#!/bin/sh
。。。
set -x
#脚本的主要内容
set +x
。 。。
而且在rcS文件里增加例如以下红颜色的设置:
#!/bin/sh if [ ! -f "/var/log/rcS.log" ]; then
touch /var/log/rcS.log
fi for i in /etc/init.d/S?? * ; do
$i >> /var/log/rcS.log 2>&1
done
启动后我们在/var/log/rcS.log日志文件里看到例如以下信息:
[root@TQ2440 /etc/init.d]#cat /var/log/rcS.log
+ [ ! -f ]
+ touch /var/log/ifup-wlan.log
+ log=/var/log/ifup-wlan.log
+ [ -z ]
+ export network_cfg_dir=/etc/network
+ cd /etc/network
+ sed -e /ifcfg-[A-Za-z0-9\._-]\+$/ { s/^ifcfg-//g;s/[0-9]/ &/}
+ ls ifcfg-wlan0
+ sed s/ //
+ sort -k 1,1 -k 2n
+ interfaces=wlan0
+ ifconfig lo 127.0.0.1
+ [ -z wlan0 ]
+ unset DEVICE TYPE
+ fgrep DEVICE= ifcfg-wlan0
+ eval DEVICE=wlan0
+ DEVICE=wlan0
+ fgrep TYPE= ifcfg-wlan0
+ eval TYPE=WLAN
+ TYPE=WLAN
+ [ -z wlan0 ]
+ egrep -L ^ONBOOT=['"]?[Nn][Oo]['"]? ifcfg-wlan0
+ [ WLAN = Ethernet ]
+ [ WLAN = PPP ]
+ [ WLAN = WLAN ]
+ [ -d /sys/class/net/wlan0/ ]
+ /etc/network/ifup-wlan wlan0
+ route del default dev eth0
route: SIOCDELRT: No such process
+ route add default gw 192.168.1.1
+ set +x
+ [ ! -f ]
+ touch /var/log/ifup-wlan.log
+ log=/var/log/ifup-wlan.log
+ [ -z ]
+ export network_cfg_dir=/etc/network
+ cd /etc/network
+ ls ifcfg-wlan0
+ sed -e /ifcfg-[A-Za-z0-9\._-]\+$/ { s/^ifcfg-//g;s/[0-9]/ &/}
+ sed s/ //
+ sort -k 1,1 -k 2n
+ interfaces=wlan0
+ ifconfig lo 127.0.0.1
+ [ -z wlan0 ]
+ unset DEVICE TYPE
+ fgrep DEVICE= ifcfg-wlan0
+ eval DEVICE=wlan0
+ DEVICE=wlan0
+ fgrep TYPE= ifcfg-wlan0
+ eval TYPE=WLAN
+ TYPE=WLAN
+ [ -z wlan0 ]
+ egrep -L ^ONBOOT=['"]?[Nn][Oo]['"]? ifcfg-wlan0
+ [ WLAN = Ethernet ]
+ [ WLAN = PPP ]
+ [ WLAN = WLAN ]
+ [ -d /sys/class/net/wlan0/ ]
+ /etc/network/ifup-wlan wlan0
并没有发现什么问题。
第二步,開始定位ifup-wlan脚本文件是否有问题。并做了相似上面的改动。
#!/bin/sh
if [ ! -f "$log" ]; then
touch /var/log/ifup-wlan.log
log=/var/log/ifup-wlan.log
fi
。。。
$network_cfg_dir/ifup-wlan $i >> ${log} 2>&1
。。。
启动后查看/var/log/ifup-wlan.log文件,看到如信息:
[root@TQ2440 /etc/init.d]#cat /var/log/ifup-wlan.log
。。。
+ /apps/tools/wpa_supplicant -B -Dwext -iwlan0 -c/etc/network/wpa_supplicant.conf
/apps/tools/wpa_supplicant: can't load library 'libnl.so.1'
。。。
也就是说,在运行wpa_supplicant程序时,没有找到libnl.so.1库文件。问题就出在这里。
于是,我又在/apps/tools/wpa_supplicant -B -Dwext -iwlan0 -c/etc/network/wpa_supplicant.conf这个命令前增加export发现:
+ export
export HOME='/'
export OLDPWD='/etc/network'
export PATH='/sbin:/usr/sbin:/bin:/usr/bin'
export PWD='/etc/network'
export SHELL='/bin/sh'
export TERM='vt102'
export USER='root'
export network_cfg_dir='/etc/network'
+ /apps/tools/wpa_supplicant -B -Dwext -iwlan0 -c/etc/network/wpa_supplicant.conf
/apps/tools/wpa_supplicant: can't load library 'libnl.so.1'
这个和我在终端上运行export命令看到的结果不一样:
[root@TQ2440 ~]#export
export DMALLOC_OPTIONS='debug=0x34f47d83,inter=100,log=logfile'
export EDITOR='/bin/vi'
export HISTFILESIZE='1000'
export HISTSIZE='1000'
export HOME='/'
export HOSTNAME='TQ2440'
export INPUTRC='/etc/inputrc'
export LD_LIBRARY_PATH='/apps/tslib/lib:/apps/lib'
export LOGNAME='root'
export PAGER='/bin/more '
export PATH='/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/apps/bin:/apps/tools:/apps/tslib/bin:'
export PS1='[\u@\h \w]#'
export PWD='/'
export QT_QWS_FONTDIR='/apps/lib/fonts'
export QWS_MOUSE_PROTO='tslib:/dev/event1'
export SHELL='/bin/sh'
export TERM='vt100'
export TSLIB_CALIBFILE='/etc/pointercal'
export TSLIB_CONFFILE='/apps/tslib/etc/ts.conf'
export TSLIB_CONSOLEDEVICE='none'
export TSLIB_PLUGINDIR='/apps/tslib/lib/ts'
export TSLIB_ROOT='/apps/tslib'
export TSLIB_TSDEVICE='/dev/event1'
export USER='root'
export VAR1=''
export VAR2=''
export VAR3=''
export VAR4=''
export VAR5=''
这些环境变量是在profile文件里设置的,原来当登录后。Init进程会分配给你一个shell,这个shell才会读/etc/profile这个脚本作为环境变量。因此没有登录就不会有使能profile文件。
解决方法:
在ifup-wlan脚本的这个位置增加红颜色的语句。
export LD_LIBRARY_PATH=/lib:/usr/lib:$TSLIB_ROOT/lib:/apps/lib
/apps/tools/wpa_supplicant -B -Dwext -i$DEVICE -c${network_cfg_dir}/wpa_supplicant.conf
就是将缺少的这个libnl库的路径增加到库路径的环境变量中。
运行一遍后,wifi就已经连接上了。
shell重定向调试信息的更多相关文章
- shell输出调试信息
[shell输出调试信息] 1.使用trap命令 trap命令用于捕获指定的信号并执行预定义的命令. 其基本的语法是: trap 'command' signal 其中signal是要捕获的信号,co ...
- linux输出信息调试信息重定向
最近在做一个android系统移植的项目,所使用的开发板com1是调试串口,就是说会有uboot和kernel的调试信息打印在com1上(ttySAC0).因为后期要使用ttySAC0作为上层应用通信 ...
- shell脚本调试
转自:http://www.ibm.com/developerworks/cn/linux/l-cn-shell-debug/ 一. 前言 shell编程在unix/linux世界中使用得非常广泛,熟 ...
- 【转】Linux Shell脚本调试技术
本文转载自:https://www.ibm.com/developerworks/cn/linux/l-cn-shell-debug/ Shell脚本调试技术 本文全面系统地介绍了shell脚本调试技 ...
- shell脚本调试技术_转
转自:http://itlab.idcquan.com/linux/SHELL/727128.html 参考:https://linux.cn/article-8045-1.html 本文全面系统地介 ...
- 【转】shell脚本调试(bash trap support bashdb )
原文网址:http://zhu8337797.blog.163.com/blog/static/170617549201122512712136/ 命 令 选 项 功 能 bash –x 脚本名 回显 ...
- Shell脚本调试技术
http://www.ibm.com/developerworks/cn/linux/l-cn-shell-debug/ 一. 前言 shell编程在unix/linux世界中使用得非常广泛,熟练掌握 ...
- Linux Shell 程序调试
Linux Shell 程序调试 Shell程序的调试是通过运行程序时加入相关调试选项或在脚本程序中加入相关语句,让shell程序在执行过程中显示出一些可供参考的“调试信息”.当然,用户也可以在she ...
- Linux Shell 脚本调试
方法如下所示:(1) 使用选项–x,启用shell脚本的跟踪调试功能: $ bash -x script.sh 运行带有-x标志的脚本可以打印出所执行的每一行命令以及当前状态.注意,你也可以使用sh ...
随机推荐
- 多线程程序设计学习(8)Thread-Per-Message
Thread-Per-Message[这个工作交给你模式]一:Thread-Per-Message的参与者--->Client(委托人)--->host(中介开线程)--->hepl ...
- (转)solr排序OOM解决方法
转自 http://topcat.iteye.com/blog/1293650 问题 lucene使用排序时会将被排序字段全部加入内存再进行排序,当多次使用不同字段进行排序时会造成OOM问题 解决方案 ...
- FirstOrDefault
FirstOrDefault:取序列中满足条件的第一个元素,如果没有元素满足条件,则返回默认值(对于可以为null的对象,默认值为null,对于不能为null的对象,如int,默认值为0)
- MySQL SQL优化之字符串索引隐式转换
之前有用户很不解:SQL语句非常简单,就是select * from test_1 where user_id=1 这种类型,而且user_id上已经建立索引了,怎么还是查询很慢? test_1的表结 ...
- HDU 5617 Jam's maze 巧妙DP
题意:给你一个字符矩阵,从(1,1)到(n,n)有很多种走法,每一种走法形成一个字符串,问有多少种走法形成的字符串是回文的 分析:(粘贴BC题解) 的是回文串,有人会想到后缀数组自动机马拉车什么的,其 ...
- 介绍并扩展Fitnesse的测试模块化机制:ScenarioTable
摘要:在验收测试框架Fitneese中,使用Scenario可以把最常用的测试步骤封装起来,从而达到模块化定义Fitnesse测试用例的能力.但Scenario仅限于封装Script测试步骤,Scri ...
- java.lang.ExceptionInInitializerError的原因(转)
这个错误是说变量初始化出现问题,通常出现在静态变量尤其是单例模式.这种问题往往是初始化顺序不对造成的,下面举个简单的例子. import java.util.HashMap; import java. ...
- mac远程连接 win8
首先 打开组策略 .windows8 下 按win+R 可以唤出运行,输入[gpedit.msc]按下 回车键 选择[计算机配置]>[管理模板]>[Windows组件]>[远程桌面服 ...
- bzoj 3295 [Cqoi2011]动态逆序对(cdq分治,BIT)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3295 [题意] n个元素依次删除m个元素,求删除元素之前序列有多少个逆序对. [思路] ...
- 部分常用Express方法详解
app.set(name, value) 分配给name一个value,并将name作为app settings table的一个属性. 使用app.set('foo', true) 相当于调用 ap ...