第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Bash腳本-將stderr存儲(chǔ)在變量中

Bash腳本-將stderr存儲(chǔ)在變量中

千萬里不及你 2019-12-02 09:55:17
我正在編寫一個(gè)腳本來備份數(shù)據(jù)庫(kù)。我有以下幾行:mysqldump --user=$dbuser --password=$dbpswd  \   --host=$host $mysqldb | gzip > $filename我想將stderr分配給一個(gè)變量,以便它將向自己發(fā)送一封電子郵件,讓我知道如果出現(xiàn)問題,會(huì)發(fā)生什么。我已經(jīng)找到了將stderr重定向到stdout的解決方案,但是由于stdout已經(jīng)(通過gzip)發(fā)送到文件中,因此我無法做到這一點(diǎn)。如何將stderr分別存儲(chǔ)在變量$ result中?
查看完整描述

3 回答

?
精慕HU

TA貢獻(xiàn)1845條經(jīng)驗(yàn) 獲得超8個(gè)贊

嘗試將stderr重定向到stdout并$()用于捕獲它。換一種說法:


VAR=$((your-command-including-redirect) 2>&1)

由于您的命令將stdout重定向到某個(gè)地方,因此它不應(yīng)干擾stderr??赡苡幸环N更簡(jiǎn)潔的編寫方法,但這應(yīng)該可行。


編輯:


這確實(shí)有效。我已經(jīng)測(cè)試過了:


#!/bin/bash                                                                                                                                                                         

BLAH=$((

(

echo out >&1

echo err >&2

) 1>log

) 2>&1)


echo "BLAH=$BLAH"

將打印BLAH=err并且文件log包含out。


查看完整回答
反對(duì) 回復(fù) 2019-12-02
?
料青山看我應(yīng)如是

TA貢獻(xiàn)1772條經(jīng)驗(yàn) 獲得超8個(gè)贊

對(duì)于Bash中的任何通用命令,您可以執(zhí)行以下操作:


{ error=$(command 2>&1 1>&$out); } {out}>&1

常規(guī)輸出正常出現(xiàn),任何將stderr的內(nèi)容都捕獲在$ error中(使用它保存換行符時(shí)將其引用為“ $ error”)。要將stdout捕獲到文件,只需在末尾添加重定向,例如:


{ error=$(ls /etc/passwd /etc/bad 2>&1 1>&$out); } {out}>&1 >output

分解它,從外面讀入它:


為整個(gè)塊創(chuàng)建文件描述$ out,復(fù)制stdout

在$ error中捕獲整個(gè)命令的標(biāo)準(zhǔn)輸出(但請(qǐng)參見下文)

該命令本身將stderr重定向到stdout(在上面捕獲),然后將stdout從塊外部重定向到原始stdout,因此僅捕獲stderr


查看完整回答
反對(duì) 回復(fù) 2019-12-02
?
收到一只叮咚

TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超5個(gè)贊

您可以將stdout引用從重定向之前保存到另一個(gè)文件號(hào)(例如3)中,然后將stderr重定向到該文件:


result=$(mysqldump --user=$dbuser --password=$dbpswd  \

   --host=$host $mysqldb 3>&1 2>&3 | gzip > $filename)

因此3>&1會(huì)將文件編號(hào)3重定向到stdout(注意,這是在使用管道將stdout重定向之前)。然后2>&3將stderr重定向到3號(hào)文件,該文件現(xiàn)在與stdout相同。最后,將stdout通過饋入管道進(jìn)行重定向,但這不會(huì)影響文件編號(hào)2和3(請(qǐng)注意,從gzip重定向stdout與mysqldump命令的輸出無關(guān))。


編輯:更新了命令以從命令重定向stderr mysqldump而不是gzip,我的第一個(gè)答案太快了。


查看完整回答
反對(duì) 回復(fù) 2019-12-02
  • 3 回答
  • 0 關(guān)注
  • 905 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)