linux脚本输出命令到 linux执行脚本输出日志

linux shell脚本执行命令详解在Linux下,如果你需要执行shell脚本 , 那么应该使用那个命令呢?下面由我为大家整理了linux shell脚本执行命令的相关知识,希望对大家有帮助!
linux shell脚本执行
linux shell脚本执行方法一: 切换到shell脚本所在的目录(此时 , 称为工作目录)执行shell脚本:
cd /data/shell
./hello.sh
./的意思是说在当前的工作目录下执行hello.sh 。如果不加上./,bash可能会响应找到不到hello.sh的错误信息 。因为目前的工作目录(/data/shell)可能不在执行程序默认的搜索路径之列,也就是说,不在环境变量PASH的内容之中 。查看PATH的内容可用 echo $PASH 命令 。现在的/data/shell就不在环境变量PASH中的 , 所以必须加上./才可执行 。
linux shell脚本执行方法二: 以绝对路径的方式去执行bash shell脚本:
/data/shell/hello.sh
linux shell脚本执行方法三: 直接使用bash 或sh 来执行bash shell脚本:
cd /data/shell
bash hello.sh

cd /data/shell
sh hello.sh
注意,若是以方法三的方式来执行 , 那么,可以不必事先设定shell的执行权限,甚至都不用写shell文件中的第一行(指定bash路径) 。因为方法三是将hello.sh作为参数传给sh(bash)命令来执行的 。这时不是hello.sh自己来执行 , 而是被人家调用执行,所以不要执行权限 。那么不用指定bash路径自然也好理解了啊 。
linux shell脚本执行方法四: 在当前的shell环境中执行bash shell脚本:
cd /data/shell
. hello.sh

cd /data/shell
source hello.sh
前三种方法执行shell脚本时都是在当前shell(称为父shell)开启一个子shell环境,此shell脚本就在这个子shell环境中执行 。shell脚本执行完后子shell环境随即关闭,然后又回到父shell中 。而方法四则是在当前shell中执行的 。
linux命令输出到屏幕的同时保存到文件tee用于把命令结果打印在屏幕上并同时保存到文件 。
tee用法
描述:从标准输入中读取并同时写入到标准输出和指定的文件上
选项:
-a,--append:不覆盖,而是追加输出到指定的文件中
-i,--ignore-interrupts:忽略中断信息
若指定的输出文件为'-',则再次输出到标准输出上
实例:
tee Example.txt #将标准输入中输入的内容同时输出到Example.txt和标准输出上
实践:
例如 ifconfig | tee ifconfig.log
查看iconfig.log
注:
标准输入一般有键盘和其它文件,标准输出有屏幕等 。tee只能进行标准输入的输出,对于错误输入是不能输出的 。
在调试脚本时,想要每个命令的执行过程都输出到屏幕或者文件中,以便后续查看,如何操作呢?首先脚本第一行要写为“#!/bin/b.sh -x”,这样会把每个命令的执行记录都输出到屏幕,若还要输出到指定文件,要用到tee,但tee只能进行标准输入,对于标准输入和错误输入要用到下式:
./filename.sh 21 | tee output.log或者直接 bash -x ./filename.sh 21 | tee output.log
今天调试一个bash,要把屏幕的输出结果存到log文件中,开始输入$bash -x ./test.shlog 结果发现log里只存放了程序的执行结果,后来在cu的一篇帖子里?tid=264380highlight=bash得到了启发,bash -x的调试信息是输出到2号流中的,所以解决方案为bash -x ./test.sh 21 | tee log 想起以前要存放执行make的结果时也遇到类似问题,总结如下:
1、管道符的“I”的作用只是把前一个程序的标准输出流(stdout)的数据作为后一个程序的标准输入流stdin的数据,如不进行重定向,则其他输出流的信息是无法传给后面的程序的
2、屏幕得到的信息不一定是从程序的标准输出来的,也包括标准错误输出流stderr中的信息
3、有些程序(特别是象bash、make这样执行了其他程序的程序)的设计者为了省事 , 把一些正常情况的信息也放在stderr中输出(即使程序本身并无错误),而stdout用来输出被调用程序的执行时信息,造成了用户的误解简单编写了一下脚本,通过ssh登陆在命令行下运行正常,可是将脚本添加到crontab中就不正常 。想记录一下输出信息,分析一下错误原因 。将脚本通过使用info.log 重定向输出 , 结果发现一些在命令行下可以看到的文本信息没有记录到info.log文件中,研究了一下,那些输出估计是输出到了标准错误上 。
研究了一下通常添加命令后面几个输出含义
■ /dev/null 输出到空设备,表示丢掉输出信息 。
■ 21将输出到标准错误的信息输出到标准输出设备(通常是屏幕)有3个默认的i/o ,
■ 0是标准输入,一般是键盘
■ 1是标准输出 , 一般是屏幕
■ 2是标准错误,有时候屏幕上可以看到,但是重定向的文件中看不到的就是它了
linux中的shell脚本中输出文本内容到文件的命令是您想问的是linux中的shell脚本中输出文本内容到文件的命令是什么吗linux脚本输出命令到?shell变量调出命令 。
linux中的shell脚本有多种命令格式linux脚本输出命令到,其中输出文本内容到文件的命令包括但不限于shell文本命令调出、shell变量取值等 。
Linux操作系统是基于UNIX操作系统发展而来的一种克隆系统linux脚本输出命令到,它诞生于Linux桌面1991年10月5日(这是第一次正式向外公布的时间) 。以后借助于Internet网络,并通过全世界各地计算机爱好者的共同努力,已成为今天世界上使用最多的一种UNIX类操作系统,并且使用人数还在迅猛增长 。
【linux脚本输出命令到 linux执行脚本输出日志】linux脚本输出命令到的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux执行脚本输出日志、linux脚本输出命令到的信息别忘了在本站进行查找喔 。

    推荐阅读