shell一段脚本的一点经验(实时文件流读写)
生活随笔
收集整理的這篇文章主要介紹了
shell一段脚本的一点经验(实时文件流读写)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、腳本內容:將命令的結果實時寫入文件,再從文件中搜索指定字符串,并返回含有該字符串的行數。
2、正確的腳本:
#!/bin/bash #find the lost glabelingtopo and restart #write by Jason.F #2016.07.29#assert 12 processes jps > /home/topo.log declare -i jpsnum=0 #var=`find /home/ -type f -name "topo.log" | xargs grep "name"` jpsnum=$(grep -c name /home/topo.log) if [ $jpsnum -eq 12 ]; then rm -rf /home/topo.log exit 0 fi3、錯誤的腳本: #!/bin/bash #find the lost glabelingtopo and restart #write by Jason.F #2016.07.29#assert 12 processes jps > /home/topo.log & declare -i jpsnum=0 #var=`find /home/ -type f -name "topo.log" | xargs grep "name"` jpsnum=$(grep -c name /home/topo.log) if [ $jpsnum -eq 12 ]; then rm -rf /home/topo.log exit 0 fi
4、經驗:
兩個腳本的區別在于jps > /home/topo.log ,錯誤的腳本加了&,導致錯誤的腳本執行中,jpsnum一直為零。猜測是因為加了&,變成后臺異步將命令結果寫入到文件,而當前任務從文件中搜索的實際是一份還未關閉寫入的空文件,所以返回是零。去掉&,就是完成文件寫入并保存文件后,才開始在文件中搜索,而錯誤腳本確實未保存文件就搜索,自然搜索不到內容。
總結
以上是生活随笔為你收集整理的shell一段脚本的一点经验(实时文件流读写)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在线实时大数据平台Storm本地模式运行
- 下一篇: 算法导论之二项堆