脚本代码
linux上多次重启,USB识别信息记录自动测试脚本
记录重启时usb设备枚举的信息,并存到log中。重启测试次数可以自己设置。
#!/bin/bash
logpath="/home/xaob/rebootlog.txt" #log文件
templogpath=""${HOME}""/temptest.txt"" #零时log文件
numpath="/home/xaob/numtest.txt" #测试次数文件 echo 0>numtest.txt 可以重置测试次数
setpath="/home/xaob/setnum.txt" #设置测试最大次数,测试测试大于该值,停止测试,中途拔掉设备,会测试失败,也会停止测试
#检测文件是否存在
if test -e $setpath
then
echo exisit
else
echo creat setnum.txt
echo 10 > $setpath
fi
#获取设置次数
num=$(cat $setpath)
#获取测试次数
testnum=$(($(cat $numpath)+1))
echo $testnum
#累加并输出次数
echo $testnum > $numpath
#输出log
echo ----------------------------------------- >> $logpath
date >> $logpath
echo ------------------$testnum-------------- >> $logpath
lsusb >> $logpath
#lsusb > $templogpath
#查找文件内容
#grep "SEGGER" $templogpath> /dev/null
#if [ $? -eq 0 ]
#then
if test $[testnum] -gt $[num]
then
echo end of test
else
# echo start
shutdown -r now
fi
#fi
开机启动一
方法一
设置硬链接
sudo ln ****.sh /etc/init.d/****.sh
设置开机启动
sudo update-rc.d new_service.sh defaults 90
#sudo update-rc.d new_service.sh enable 5 defaults 90
方法二(推荐)
将默认的shell改成bash的方法:
-
在终端执行 sudo dpkg-reconfigure dash,然后选择 no (推荐)
-
sudo rm /bin/sh
sudo ln -s /bin/bash /bin/sh
或者将 /etc/rc.local 中的/bin/sh -e 改为/bin/bash -
sudo vim /ext/rc.local
在 /etc/rc.local种 exit 0 前添加下面代码
echo "你的密码"|sudo -S bash /home/user/xx.sh
-e 在脚本种如果有判断 $? 一旦上条语句返回值错误(非0),脚本就会自动退出.
改启动等待时间
sudo vim /etc/default/grub
修改:
GRUB_DEFAULT=0 # 从0开始计数,默认是0,想要哪个当启动项就改成相应的数字
GRUB_TIMEOUT=10 # 等待选择时间,单位是秒,自己随便设
修改完之后需要运行命令:sudo update-grub,使修改生效
开机启动二
这个与上面开机启动的区别在于:启动的顺序不一样,上面方法二的在界面出来后,过一段时间才运行;方法一在界面还没出来就运行了,具体可以开一下linux的启动顺序。
本方法在界面出来的时候同步运行,比如你要开机打开摄像头显示,这个方法就比较适用,上面方法一运行太早显示不出来,方法二得等一下,所以这个方法就比较适用。
脚本
#!/bin/bash
cd temp/ #相对路径和绝对路径都可以
echo "你的密码"|sudo -S ./xxtest.sh #这个是sudo 运行 不需要的直接 ./xxtest.sh
添加开机启动
alt+F2,输入gnome-session-properties
在command栏里 直接点击浏览,选择刚才写的脚本
问题
方法一 可以执行,但是当测试一两波之后(中间修改过代码),会失效。
方法二 可以执行像echo xx> xx.txt的命令, 但是就是不能执行脚本,后面发现应该是路径和-e得问题,代码如下:
echo start > /home/user/log.txt #可以执行
bash /home/user/xx.sh #不会执行
echo end > /home/user/log.txt #可以执行
exit 0
难用,非常的奇怪。
解决
改rc.local
echo start > /home/user/log.txt #可以执行
echo "你的密码"|sudo -S bash /home/user/xx.sh #不会执行
echo end > /home/user/log.txt #可以执行
exit 0
改代码
代码中不能使用
logpath=""${HOME}""/rebootlog.txt""
numpath=""${HOME}""/numtest.txt""
templogpath=""${HOME}""/temptest.txt""
setpath=""${HOME}""/setnum.txt""
改成绝对路径
logpath="/home/user/rebootlog.txt"