shell启动脚本中的0、1、2、>和&解析

目录

一、0 1 2 文件描述符

二、>是重定向符,就是把前面输出的内容重定向到后面指定的位置

三、& 是一个描述符,如果1或2前不加&,会被当成一个普通文件

nohup sh gmv.sh >ls.txt 2>&1 &  后台运行脚本的一般格式,并且把日志(正常日志和错误日志)输出到ls.txt中

tail -f ls.txt可以动态查看日志

一、0 1 2 文件描述符
在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是:
0 是一个文件描述符,表示标准输入(stdin)
1 是一个文件描述符,表示标准输出(stdout)
2 是一个文件描述符,表示标准错误(stderr)

在标准情况下, 这些FD分别跟如下设备关联: 
stdin(0): keyboard 键盘输入,并返回在前端 
stdout(1): monitor 正确返回值 输出到前端 
stderr(2): monitor 错误返回值 输出到前端

举例说明吧:假如当前目录只有一个文件 a.txt
[root@redhat box]# ls 
a.txt 
[root@redhat box]# ls a.txt b.txt 
ls: b.txt: No such file or directory 由于没有b.txt这个文件, 于是返回错误值, 这就是所谓的2输出 
a.txt 而这个就是所谓的1输出

二、>是重定向符,就是把前面输出的内容重定向到后面指定的位置
再接着看:
[root@redhat box]# ls a.txt b.txt 1>file.out 2>file.err 
执行后,没有任何返回值. 原因是, 返回值都重定向到相应的文件中了,而不再前端显示 
[root@redhat box]# cat file.out 
a.txt 
[root@redhat box]# cat file.err 
ls: b.txt: No such file or directory 
一般来说, "1>" 通常可以省略成 ">". 
即可以把如上命令写成: ls a.txt b.txt >file.out 2>file.err 
有了这些认识才能理解 "1>&2" 和 "2>&1". 
1>&2 正确返回值传递给2输出通道 &2表示2输出通道 
如果此处错写成 1>2, 就表示把1输出重定向到文件2中. 
2>&1 错误返回值传递给1输出通道, 同样&1表示1输出通道. 
举个例子. 
[root@redhat box]# ls a.txt b.txt 1>file.out 2>&1 
[root@redhat box]# cat file.out 
ls: b.txt: No such file or directory 
a.txt 
现在, 正确的输出和错误的输出都定向到了file.out这个文件中, 而不显示在前端. 
补充下, 输出不只1和2, 还有其他的类型, 这两种只是最常用和最基本的.

>是重定向符,就是把前面输出的内容重定向到后面指定的位置,比如(例1):
echo "一些内容" > filename.txt
上面例子会把 "一些内容" 写入到 filename.txt 文件中。

>前是可以加数字来说明把什么内容重定向到文件中,默认是把标准输出重定向到文件中,所以下面这个例子和上面那个是一样的(例2):
echo "一些内容" 1> filename.txt
如果是错误信息就不会输出到filename.txt(例3):

$ ls nodir 1> filename.txt
$ ls: nodir: No such file or directory
上面这个例子中nodir不存在,所以通过ls命令查询时错误信息会输出到 2(stderr),但我们指定的是把1重定向到filename.txt,所以上面命令执行完后,filename.txt中是没有内容的。但是执行下面命令就会把错误信息写入到filename.txt中(例4):

$ ls nodir 2> filename.txt
$ cat filename.txt
$ ls: nodir: No such file or directory

三、& 是一个描述符,如果1或2前不加&,会被当成一个普通文件
1>&2 意思是把标准输出重定向到标准错误.
2>&1 意思是把标准错误输出重定向到标准输出。
&>filename 意思是把标准输出和标准错误输出都重定向到文件filename中

我们再看一个例子(列5):
$ ls nodir 1> filename.txt 2>&1
$ cat filename.txt
$ ls: nodir: No such file or directory
上面例子把 标准输出 重定向到文件 filename.txt,然后把 标准错误 重定向到 标准输出,所以最后的错误信息也通过标准输出写入到了文件中,比较例3,4,5,就能明白其作用。

问:Linux重定向中 >&2 怎么理解?
问题补充:echo "aaaaaaaaaaaaaaaa" >&2 怎么理解?
答:>&2 即 1>&2 也就是把结果输出到和标准错误一样;之前如果有定义标准错误重定向到某log文件,那么标准输出也重定向到这个log文件
如:ls 2>a1 >&2 (等同 ls >a1 2>&1)
把标准输出和标准错误都重定向到a1,终端上看不到任何信息。
---------------------
作者:哎呦、不错哦
来源:CSDN
原文:https://blog.csdn.net/l1394049664/article/details/81710705
版权声明:本文为博主原创文章,转载请附上博文链接!

原文地址:https://www.cnblogs.com/lgjava/p/10634866.html

时间: 2024-10-19 02:52:33

shell启动脚本中的0、1、2、>和&解析的相关文章

启动脚本中避免目标地址为域名的网络连接

项目启动脚本想要判断当前网络环境(内网是否连通),于是加了如下脚本代码:     ping -c1 -W1 xxx.xxx.com > /dev/null     if [ $? = 0 ]; then 我们的项目启动脚本安装到/etc/init.d/下面了,因此会随服务器重启而启动.于是就出现了下面的情景: 某些服务器启动花了几十分钟时间才启动完成. 这部分服务器在启动的时候网络不通. 解决方法将脚本改成如下:     ping -c1 -W1 172.xxx.xxx.xx > /dev/n

rails+unicorn+nginx配置、shell启动脚本

1.nginx 配置文件 1.1.项目目录放在系统/var/www/ upstream app { # Path to Unicorn SOCK file, as defined previously server unix:/var/www/app/shared/sockets/unicorn.sock fail_timeout=0; #server 127.0.0.1:4000 fail_timeout=0; } server { listen 80; server_name app.exa

shell脚本中的$# $0 [email protected] $* $$ $! $?的意义

转载自:http://www.cnblogs.com/davygeek/p/5670212.html 今天学写脚本遇到一些变量不认识,在此做下记录. 变量 含义 $0 当前脚本的文件名 $n 传递给脚本或函数的参数.n 是一个数字,表示第几个参数.例如,第一个参数是$1,第二个参数是$2 $# 传递给脚本或函数的参数个数 $* 传递给脚本或函数的所有参数 [email protected] 传递给脚本或函数的所有参数.被双引号(" ")包含时,与 $* 稍有不同 $? 上个命令的退出状

Dubbo 官方 shell 启动脚本(带JVM参数)

#!/bin/bash cd `dirname $0` BIN_DIR=`pwd` cd .. DEPLOY_DIR=`pwd` CONF_DIR=$DEPLOY_DIR/conf SERVER_NAME=`sed '/dubbo.application.name/!d;s/.*=//' conf/dubbo.properties | tr -d '\r'` SERVER_PROTOCOL=`sed '/dubbo.protocol.name/!d;s/.*=//' conf/dubbo.pro

说说shell脚本中的export 和 source,bash

小弟刚刚接触linux,对linux上的很多东西都比较陌生,所以写一写博客,当做自己工作的总结和技术的积累吧,也是鞭策自己不断努力的去学习. 今天之所以起这个标题,把export,source ,bash这三个命令放在一起讲,实在是因为自己做了一件蠢事. 什么样的蠢事先不说.先分析下这三个命令. 首先是export命令. 1.export命令 Linux export命令用于设置或显示环境变量. 在shell中执行程序时,shell会提供一组环境变量.export可新增,修改或删除环境变量,供后

shell脚本中的export 和 source,bash

1.export命令 Linux export命令用于设置或显示环境变量. 在shell中执行程序时,shell会提供一组环境变量.export可新增,修改或删除环境变量,供后续执行的程序使用.同时,重要的一点是,export的效力仅及于该次登陆操作.注销或者重新开一个窗口,export命令给出的环境变量都不存在了. 该命令的语法如下: export [-fnp][变量名称]=[变量设置值] 其中: -f 代表[变量名称]中为函数名称. -n 删除指定的变量.变量实际上并未删除,只是不会输出到后

ubuntu18.04设置启动脚本

需要在启动时自动执行init_frpc.sh脚本,以下为脚本内容 cd [dir of frpc config files] #使用nohup保证frpc在后台运行 nohup ./frpc -c ./frpc.ini & 1.复制或软连接脚本到/etc/init.d/目录下 2.将脚本添加到初始化执行的队列中去 注意如果脚本需要用到网络,则NN需设置一个比较大的数字,如99. 命令:update-rc.d filename defaults NN命令 #(NN为启动顺序) ubuntu 18.

linux中BASH_SOURCE[0]

在C/C++中,__FUNCTION__常量记录当前函数的名称.有时候,在日志输出的时候包含这些信息是非常有用的.而在Bash中,同样有这样一个常量FUNCNAME,但是有一点区别是,它是一个数组而非字符串,其中数组的第一个元素为当前函数的名称.可能初看有点难以理解,为什么FUNCNAME要是一个数组呢?看看下面的例子,你就明白了. 1 #!/bin/bash 2 3 function test_func() 4 { 5 echo "Current $FUNCNAME, \$FUNCNAME =

启动脚本

centerOs: centeros 开机启动:/etc/rc.local 加入如 su - hujh -c ‘/home/hujha/apache-tomcat-7/bin/start.sh’ Ubuntu下添加开机启动脚本 1.方法一,编辑rc.loacl脚本  Ubuntu开机之后会执行/etc/rc.local文件中的脚本, 所以我们可以直接在/etc/rc.local中添加启动脚本. 当然要添加到语句:exit 0 前面才行. 如: sudo vi /etc/rc.local 然后在