파이프라인에서 특정 명령의 종료 상태를 어떻게 얻나요? [복사]

파이프라인에서 특정 명령의 종료 상태를 어떻게 얻나요? [복사]

while스크립트에서 이 루프를 실행하여 이를 가져와 압축하고 있지만 mysqldump스크립트가 존재하지 않는 경우 해당 스크립트를 원합니다. 내가 시도한 것은 다음과 같습니다.exittable

while read TABLES; do
    sudo mysqldump $DB $TABLES | gzip -f > $DB.$TABLES.sql.gz
    if [ $? != 0 ]; then
        echo "mysqldump Query executed with error !!"
        exit 1
    fi
done < file

그러나 이는 종료 상태를 제공 gzip -f하지만 종료 상태는 제공하지 않습니다 mysqldump. mysqldump거기에서 사용하지 않으면 종료 상태를 얻을 수 있다는 것을 알고 있지만 gzip이 방법에 대한 종료 상태를 얻을 수 있는 방법이 있습니까 mysqldump?

답변1

PIPESTATUS 변수를 사용하여 파이프라인 각 요소의 종료 상태를 얻을 수 있습니다.

if [ ${PIPESTATUS[0]} -ne 0 ];then
        echo "mysqldump Query executed with error !!"
        exit 1
    fi

관련 정보