Linux Shell如何获取各个管道的返回码&Bash Ubuntu CentOS PIPESTATUS curl grep
创始人
2025-01-15 18:05:22
0

在这里插入图片描述

问题

当我们在linux shell(如bash)中使用管道执行多个命令时,$?只能获取到最后一条命令的返回码,那么应该怎么获取管道前面的命令的返回码呢,请看下文:

当执行一条管道命令时,linux会使用PIPESTATUS这个数组变量来保存每个管道的返回码。PIPESTATUS[0]表示管道中第一个命令的返回码,PIPESTATUS[1]表示第二个命令的返回值,这是一个共享的变量,为避免别的命令改变它的内容,可以将它复制到一个新的数组。

#!/bin/bash echo "tftf" true | false | true | false RC=( "${PIPESTATUS[@]}" ) echo "RC[0] = ${RC[0]}"        # true = 0 echo "RC[1] = ${RC[1]}"        # false = 1 echo "RC[2] = ${RC[2]}"        # true = 0 echo "RC[3] = ${RC[3]}"        # false = 1  echo "ftft" false | true | false | true RC=( "${PIPESTATUS[@]}" ) echo "RC[0] = ${RC[0]}"        # false = 1 echo "RC[1] = ${RC[1]}"        # true = 0 echo "RC[2] = ${RC[2]}"        # false = 1 echo "RC[3] = ${RC[3]}"        # true = 0  echo "fftt" false | false | true | true RC=( "${PIPESTATUS[@]}" ) echo "RC[0] = ${RC[0]}"        # false = 1 echo "RC[1] = ${RC[1]}"        # false = 1 echo "RC[2] = ${RC[2]}"        # true = 0 echo "RC[3] = ${RC[3]}"        # true = 0 

执行上面的bash文件,输出如下所示:

jagitch@jagitch-MS-7B93:~$ source pipeline.sh tftf RC[0] = 0 RC[1] = 1 RC[2] = 0 RC[3] = 1 ftft RC[0] = 1 RC[1] = 0 RC[2] = 1 RC[3] = 0 fftt RC[0] = 1 RC[1] = 1 RC[2] = 0 RC[3] = 0 

一个具体的实例

#!/bin/bash WEB_SERVER=steve-parker.org curl -# -f -u ${USERNAME}:${PASSWORD} http://${WEB_SERVER}/ | grep "SomeMessage" RC=( "${PIPESTATUS[@]}" ) if [ "${RC[0]}" -eq "22" ]; then   # curl returned 22, indicating some error above 400,   # such as: 404 Not Found, 401 Unauthorized, etc.   echo "Invalid credentials"   exit 1 fi  # PIPESTATUS has gone, but we can still inspect RC if [ "${RC[1]}" -eq "0" ]; then   echo "Grep succeeded"   echo "Web server reported SomeMessage" else   echo "Web server didn't report SomeMessage" fi 

推荐阅读

1. 使用树梅派搭建Golang、Python、NodeJs的开发服务器

2. 教你如何1秒安装一个Linux系统(ubuntu,debian,centos) 比虚拟机安装系统省时省心省力

3. 超级详细的Github双重验证开启教程&github Two-factor authentication

相关内容

热门资讯

【Rust】——所有可能会用到... 💻博主现有专栏:                C51单片机ÿ...
java: 错误: 不支持发行... 左下角搜索输入cmd打开控制台窗口输入java -version查看自己Java的版本,...
Apache Flink核心特... Flink的定义Apache Flink是一个分布式处理引擎,用于处理 无边界数据流&...
解密Spring Boot:深... 文章目录一、条件装配概述1.1 条件装配的基本原理1.2 条件装配的作用二、常用注解2.1 @...
玩家爆料!wepoke辅助有挂... 玩家爆料!wepoke辅助有挂的,AAPoKer软件透明挂,有挂套路(2023已更新)(哔哩哔哩);...
使用wheelnav.js构建... 目录前言一、WheelNav是什么1、项目地址2、关于开源协议3、相关目录介绍二、如何使用wheel...
六分钟了解(royalpoke... 六分钟了解(royalpoker)软件透明挂(辅助挂)透明挂工具(2020已更新)(哔哩哔哩);详细...
必知辅助挂小闲有外挂!太离谱了... 必知辅助挂小闲有外挂!太离谱了原来真的有挂(2022已更新)(有挂教会);小闲有外挂是一款益智类棋牌...
告别冗长代码:Java Lam... 在现代软件开发中,高效和简洁的代码变得越来越重要。Java作为一门成熟而广泛使用的编程...
最新通报!线上wpk到底有外挂... 您好,微扑克这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中...