當(dāng)前位置:首頁(yè) > 充電吧 > 充電吧
[導(dǎo)讀]上周我與同事們進(jìn)行了一次關(guān)于職業(yè)生涯中搞砸了一些事情的簡(jiǎn)短談話。這確實(shí)會(huì)淪為他人笑柄,卻更給我們帶來(lái)了珍貴的教訓(xùn)。重要的是,我們應(yīng)該分享那些曾經(jīng)的錯(cuò)誤,這樣其他人就可以從其中學(xué)習(xí)。下文是最近在我身上發(fā)生的例子。

上周我與同事們進(jìn)行了一次關(guān)于職業(yè)生涯中搞砸了一些事情的簡(jiǎn)短談話。這確實(shí)會(huì)淪為他人笑柄,卻更給我們帶來(lái)了珍貴的教訓(xùn)。重要的是,我們應(yīng)該分享那些曾經(jīng)的錯(cuò)誤,這樣其他人就可以從其中學(xué)習(xí)。下文是最近在我身上發(fā)生的例子。

為什么有如此多誤刪生產(chǎn)數(shù)據(jù)庫(kù)的事情發(fā)生?

幾個(gè)月前,Reddit上有一篇文章,講了一名初級(jí)開發(fā)人員在上班的第一天就刪除了生產(chǎn)數(shù)據(jù)庫(kù)的事。我們都很憷于讀到這類犯了這類無(wú)法讓人忘卻的大錯(cuò)誤的文章。因?yàn)槲覀冸x這些也不遠(yuǎn),而大多數(shù)人都是“死里逃生”。

在我的第一份工作中,一位高級(jí)數(shù)據(jù)庫(kù)管理員在上班第一天就誤刪了生產(chǎn)數(shù)據(jù)庫(kù)。這類故事情節(jié)比比皆是。這個(gè)團(tuán)隊(duì)從一個(gè)星期的備份中恢復(fù)了他導(dǎo)致的錯(cuò)誤,并讓他繼續(xù)工作。十年后,他們依然將其作為笑點(diǎn)。

今年早些時(shí)候,我被派去檢查一個(gè)客戶的生產(chǎn)數(shù)據(jù)上的問(wèn)題。他們進(jìn)行了小范圍的非公開測(cè)試,結(jié)果網(wǎng)站上沒(méi)有顯示任何內(nèi)容。我想查查是否是存在漏洞或是易損性問(wèn)題導(dǎo)致了這一結(jié)果。

我通過(guò)了生產(chǎn)機(jī)器上的簽名環(huán)節(jié),然后打開了數(shù)據(jù)庫(kù)。內(nèi)容庫(kù)(articles table)內(nèi)空空如也。這證實(shí)了我們?cè)诰W(wǎng)站上看到的情況是真實(shí)的。

用戶庫(kù)(users table)內(nèi)依然有用戶數(shù)據(jù)存在。真讓人奇怪。所以情況是我們丟失了所有內(nèi)容,但是至少測(cè)試用戶的信息依然存在。我們給出的解釋是這是一個(gè)測(cè)試行為,所以這些事情有可能發(fā)生。

接下來(lái)的幾分鐘一片混亂。我不記得自己做了什么。我不認(rèn)為自己笨到在控制臺(tái)上執(zhí)行了刪除用戶庫(kù)的操作。但是事實(shí)就是這么發(fā)生了,現(xiàn)在后臺(tái)既沒(méi)有了內(nèi)容庫(kù),也沒(méi)有了用戶庫(kù)。這真實(shí)下了我一大跳。

然后我的大腦就開始轉(zhuǎn)動(dòng)起來(lái)思考如何解決這個(gè)問(wèn)題。我真的把用戶庫(kù)給刪掉了嗎?是的。我們存?zhèn)浞萘藛?沒(méi)有。我們應(yīng)該如何告訴客戶這個(gè)事情?不知道。

我猶記得自己走向項(xiàng)目經(jīng)理那里,坐在她身邊,向她解釋了發(fā)生了什么事情時(shí)的場(chǎng)面。因?yàn)槲覀兊膬?nèi)容庫(kù)中沒(méi)有內(nèi)容,這就是為什么網(wǎng)站上空空如也的原因。同時(shí),我還刪除了用戶庫(kù)。他們現(xiàn)在需要重新邀請(qǐng)所有的用戶,如果他們能夠弄清楚誰(shuí)是誰(shuí)。

我回到了自己的辦公室,垂頭喪氣。

不過(guò),我還是沒(méi)有接受這件事。我們一開始是如何失去這些東西的?

我開始不停地往深處想。半是為了否認(rèn)這件事,半是想要挽回面子。不久,我注意到了一些重要事情。

在服務(wù)器上還存在著其他5個(gè)數(shù)據(jù)庫(kù)。其中一個(gè)數(shù)據(jù)庫(kù)的名字和我剛才看到的數(shù)據(jù)庫(kù)名字很像。

當(dāng)我查看這個(gè)數(shù)據(jù)庫(kù)的時(shí)候,發(fā)現(xiàn)所有的內(nèi)容都在里面。用戶庫(kù)也安然無(wú)恙。結(jié)果證明,是一個(gè)配置變動(dòng)無(wú)意中改變了生產(chǎn)設(shè)置,使站點(diǎn)指向了一個(gè)全新的數(shù)據(jù)庫(kù)。我之前所看的用戶信息是什么?種子數(shù)據(jù)。

真是謝天謝地。早上的神經(jīng)緊張和胃酸讓我覺得很不舒服,但是我們“恢復(fù)”了數(shù)據(jù),并在壞消息傳開之前找到了真正的問(wèn)題。

從這件事中可以吸取很多教訓(xùn)。其中一點(diǎn)是關(guān)于最簡(jiǎn)單原則:我們總是在做的備份,也許是開發(fā)人員最有成效的挽救藥。

繼續(xù)前進(jìn)但不要沖得過(guò)前

我最近犯的一個(gè)錯(cuò)誤不太引人注目。事實(shí)上,這是一個(gè)經(jīng)由小錯(cuò)誤所引起的小錯(cuò)誤最終導(dǎo)致了一場(chǎng)混亂的故事。

我們面臨的是一個(gè)時(shí)間緊迫的項(xiàng)目。

在初次會(huì)議上,我們團(tuán)隊(duì)一致認(rèn)為完成它會(huì)花費(fèi)比預(yù)定時(shí)間多一倍的時(shí)間。這個(gè)最后期限一開始就對(duì)我們產(chǎn)生影響,讓我寬松地通過(guò)了身份認(rèn)證部分而留有更多時(shí)間去關(guān)注客戶所實(shí)際關(guān)注的功能設(shè)計(jì)。

我只是在一個(gè)單一頁(yè)面測(cè)試了身份驗(yàn)證測(cè)試,但是當(dāng)時(shí)還不了解它們將如何被組合在一起。

把它單列出來(lái)是我做的一個(gè)錯(cuò)誤決定。我忽略了一些重要事情:

用戶在登陸之后會(huì)從cookie中加載內(nèi)容,但是這個(gè)頁(yè)面卻試圖在沒(méi)有任何等待的情況下進(jìn)行加載。根據(jù)事件的發(fā)生順序,用戶會(huì)得到帶來(lái)服務(wù)器的反映,說(shuō)其是未經(jīng)授權(quán)的。

身份驗(yàn)證也未檢查令牌是否過(guò)期。如果用戶不經(jīng)常訪問(wèn)這個(gè)網(wǎng)站。那么當(dāng)其再一次訪問(wèn)時(shí),網(wǎng)站需要用戶登出再登入才會(huì)運(yùn)行。

令牌應(yīng)該基于每個(gè)請(qǐng)求進(jìn)行更新,但是我從未花費(fèi)時(shí)間去理解其發(fā)生前后的規(guī)則。所以,這又產(chǎn)生了一個(gè)時(shí)間問(wèn)題。如果我們同時(shí)發(fā)送了幾個(gè)請(qǐng)求,根據(jù)它們返回的順序,用戶會(huì)得到那個(gè)在后來(lái)的請(qǐng)求中無(wú)法使用的令牌。

我們匆匆忙忙地趕著項(xiàng)目,卻仍花費(fèi)了比規(guī)定多一倍的時(shí)間。區(qū)別之處在于有更多的漏洞,并需要花更多時(shí)間去跟蹤并修復(fù)這些漏洞。

這使我感到窘迫。之后因?yàn)檎虑樽兊帽容^糟糕哦而讓我在公眾場(chǎng)合感到羞愧。

我想說(shuō)的是:在此之后,我花費(fèi)了時(shí)間去學(xué)習(xí)認(rèn)證程序。我現(xiàn)在了解了OAuth、JWT、刷新令牌和到期行為。我仔細(xì)研究了其他人所編寫的身份驗(yàn)證代碼。我能夠在不同的語(yǔ)言和框架中建構(gòu)身份驗(yàn)證程序。

將失敗轉(zhuǎn)化為未來(lái)的成功

這是我從那些表現(xiàn)糟糕的事情中所獲得的經(jīng)驗(yàn)。如果你愿意,那么幾乎所有好的結(jié)果都會(huì)由此而來(lái)。

如果有人能從自己的錯(cuò)誤中汲取教訓(xùn),那么他就會(huì)比現(xiàn)在更優(yōu)秀。我試著不去打擊那些第一次犯錯(cuò)誤的隊(duì)友。他們通常都知道自己把事情搞的一團(tuán)糟。

我也正嘗試不對(duì)那些不斷犯同樣錯(cuò)誤的人施加壓力。他們?nèi)匀恢档猛椤?/p>

如果在錯(cuò)誤中做到這4點(diǎn),那么你就會(huì)不斷成長(zhǎng):

嘲笑自己。

從中汲取經(jīng)驗(yàn)教訓(xùn)。

改正錯(cuò)誤。

分享自己的錯(cuò)誤,讓其他人也有所收獲。

最后,我想講一個(gè)關(guān)于錯(cuò)誤價(jià)值的軼事。20世紀(jì)初,IBM的首席執(zhí)行官托馬斯·J·沃森曾遇到過(guò)一名員工,這名員工的一系列糟糕決策讓公司付出了巨大代價(jià)。當(dāng)沃森被問(wèn)到是否會(huì)解雇這名員工時(shí),他回應(yīng)道:

“不,我剛在他身上花了60萬(wàn)美元的培訓(xùn)費(fèi)。為什么要讓別人白白撿去這個(gè)便宜?”

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉