stderr を stdout にリダイレクトしていないのに、grep が一致しない行を返すのはなぜですか?

stderr を stdout にリダイレクトしていないのに、grep が一致しない行を返すのはなぜですか?

私が使用するスクリプトは、実際には次の出力を返します。

(source /Thetra/Commun/env_ora.sh >/dev/null; sh aclenv/arun)

geIlgif0t1 -DVORACLE
geIlgif0t1
prg_25900:
ACOMP=X
geAhadlAd1 -DVORACLE
geAhadlAd1
prg_25948:
ACOMP=A
syCcgge0t1 -DVORACLE
syCcgge0t1
prg_26023:
ACOMP=S2
syVcalq0t1 -DVORACLE
syVcalq0t1
prg_26071:
ACOMP=Y
syVvali0t1 -DVORACLE
syVvali0t1
prg_26119:
ACOMP=Y
syAedit0t1 -DVORACLE
syAedit0t1
prg_26167:
(1312) DBMS WARNING: Column not found in table. (-11238)
  RETURN (-6)
    END
 END
    END
    IF cm_para_f2('VDEF','abQtip_0n1','unicite',syAedit0t1:$v_unicite)<>0
     OR null_convert$(syAedit0t1:$v_unicite,'R') <> 'F' THEN SET syAedit0t1:$v_unicite TO 'R'
    SET $v_tips_mrgl TO 'S'
    SET $v_rfbt_iban, $v_rfbt_intitule, $v_orga_creancier, $v_orga_tip_adr1, $v_orga_tip_adr2,
        $v_orga_tip_adr3, $v_code_docu, $v_tips_centre, $v_code_etab, $v_orga_tip_emetteur,
 $v_orga_emetteur, $v_rfbt_compte, $v_orga_banque, $v_rfbt_emetteur TO
    SELECT rfbt_iban, rfbt_intitule, orga_creancier, orga_tip_adr1, orga_tip_adr2, orga_tip_adr3
ACOMP=N
syAvali0t1 -DVORACLE
syAvali0t1
prg_26215:
(2751) DBMS WARNING: Column not found in table. (-11238)
 + to_string_using$(str_to_val$(substr$(clip_str$(to_string$($f_imme_no)),1,4)),'&&&&')
        + to_string_using$(str_to_val$(substr$(clip_str$(to_string$($f_sepa_propriete_no)),1,5)),'&&&&&')
    IF syAvali0t1:$v_unicite ='R' THEN
 SET $v_sepa_rum3 TO $v_sepa_rum3 + substr$(to_string_using$(syAvali0t1:$v_ordr_direct,'&&&&&&&&&'),7,9)
    ELSE
ACOMP=N
syAcalc0t1 -DVORACLE
syAcalc0t1
prg_26263:
ACOMP=N
syAcalc0t2 -DVORACLE
syAcalc0t2
prg_26311:
ACOMP=N
syAcalc0t3 -DVORACLE
syAcalc0t3
prg_26359:
ACOMP=N

エラーを確認するには、次のコマンドを使用します。

(source env_ora.sh >/dev/null; sh aclenv/arun) | egrep '^ACOMP=$'

出力:

(1312) DBMS WARNING: Column not found in table. (-11238)
  RETURN (-6)
    END
 END
    END
    IF cm_para_f2('VDEF','abQtip_0n1','unicite',syAedit0t1:$v_unicite)<>0
     OR null_convert$(syAedit0t1:$v_unicite,'R') <> 'F' THEN SET syAedit0t1:$v_unicite TO 'R'
    SET $v_tips_mrgl TO 'S'
    SET $v_rfbt_iban, $v_rfbt_intitule, $v_orga_creancier, $v_orga_tip_adr1, $v_orga_tip_adr2,
        $v_orga_tip_adr3, $v_code_docu, $v_tips_centre, $v_code_etab, $v_orga_tip_emetteur,
 $v_orga_emetteur, $v_rfbt_compte, $v_orga_banque, $v_rfbt_emetteur TO
    SELECT rfbt_iban, rfbt_intitule, orga_creancier, orga_tip_adr1, orga_tip_adr2, orga_tip_adr3
(2751) DBMS WARNING: Column not found in table. (-11238)
 + to_string_using$(str_to_val$(substr$(clip_str$(to_string$($f_imme_no)),1,4)),'&&&&')
        + to_string_using$(str_to_val$(substr$(clip_str$(to_string$($f_sepa_propriete_no)),1,5)),'&&&&&')
    IF syAvali0t1:$v_unicite ='R' THEN
 SET $v_sepa_rum3 TO $v_sepa_rum3 + substr$(to_string_using$(syAvali0t1:$v_ordr_direct,'&&&&&&&&&'),7,9)
    ELSE

grep が一致しない行を返していることがわかります。

このコマンドで stderr を stdout にリダイレクトすると、

(source /Thetra/Commun/env_ora.sh >/dev/null; sh /Thetra/Oracle/transfert/P2016.H.1/aclenv/arun) 2>&1 | egrep '^ACOMP=$'

予想どおり、出力は無効です。

stderr がリダイレクトされていないのに、grep が一致しない行を返すのはなぜですか?

答え1

このコマンドを実行すると、 というファイルstdoutと というファイルが生成されstderr、出力は次のようになります。標準出力そして出力は標準エラー出力、 それぞれ:

(source env_ora.sh >/dev/null; sh aclenv/arun) >stdout 2>stderr

コマンドgrepは送信されたデータのみを表示します標準出力ここに書き込まれたデータさえ見ていない標準エラー出力

フォローアップコメントであなたの例のバリエーションを見ると、標準出力パイプを通過して処理されるものsed:

( echo "stdout"; echo "stderr" >&2 ) | sed 's/std/STD/'
stderr
STDout

出力の他の行は、標準エラー出力チャネルはデフォルトで端末に接続されます。

要約すると、パイプラインは標準出力一つのコマンドから標準入力次の標準エラー出力チャネルは端末に接続されているため、実際のデータの流れに影響を与えることなく、エラー メッセージ (またはステータスの更新) をそこに書き込むことができます。

関連情報