摘要:不貼近真實(shí)環(huán)境的性能測(cè)試,可能會(huì)帶來(lái)不可預(yù)料的性能拓展和多線(xiàn)程問(wèn)題。也需要對(duì)負(fù)載均衡器進(jìn)行測(cè)試,以確保它能正常工作,使每個(gè)節(jié)點(diǎn)達(dá)到平衡。負(fù)載均衡器,需要的節(jié)點(diǎn)數(shù)節(jié)點(diǎn)類(lèi)型,比如是型還是型,以及聚類(lèi)要求。
生產(chǎn)過(guò)程中出現(xiàn)的問(wèn)題正逐漸得到中層和最高管理層的重視。不管是身為開(kāi)發(fā)人員還是架構(gòu)師,下列的事項(xiàng)都應(yīng)該得到你足夠的重視以避免陷入未來(lái)的尷尬境地。你也可以把它作為排查問(wèn)題的便簽。
1、不在屬性文件或XML文件中外化配置屬性。比如,沒(méi)有把批處理使用的線(xiàn)程數(shù)設(shè)置成可在屬性文件中配置。你的批處理程序無(wú)論在DEV環(huán)境中,還是UAT(用戶(hù)驗(yàn)收測(cè)試)環(huán)境中,都可以順暢無(wú)阻地運(yùn)行,但是一旦部署在PROD 上,把它作為多線(xiàn)程程序處理更大的數(shù)據(jù)集時(shí),就會(huì)拋出IOException,原因可能是JDBC驅(qū)動(dòng)版本不同,也可能是#2中討論的問(wèn)題。如果線(xiàn)程數(shù)目 可以在屬性文件中配置,那么使它成為一個(gè)單線(xiàn)程應(yīng)用程序就變得十分容易了。我們不再需要為了解決問(wèn)題而反復(fù)地部署和測(cè)試應(yīng)用了。這種方法也同樣適用于配置 URL、服務(wù)器和端口號(hào)等。
2、測(cè)試中使用的數(shù)據(jù)集規(guī)模不合適。比如,生產(chǎn)過(guò)程中一個(gè) 典型的場(chǎng)景就是只使用1到3個(gè)賬戶(hù)進(jìn)行測(cè)試,而這個(gè)數(shù)量本應(yīng)是1000到2000個(gè)的。在做性能測(cè)試時(shí),使用的數(shù)據(jù)必須是真實(shí)并且未經(jīng)裁剪的。不貼近真實(shí) 環(huán)境的性能測(cè)試,可能會(huì)帶來(lái)不可預(yù)料的性能、拓展和多線(xiàn)程問(wèn)題。只有使用更大規(guī)模的數(shù)據(jù)集對(duì)應(yīng)用程序進(jìn)行測(cè)試,才能保證它正常運(yùn)行并滿(mǎn)足非功能屬性的 SLAs(服務(wù)水平標(biāo)準(zhǔn))。
3、天真地認(rèn)為應(yīng)用程序中所調(diào)用的外部和內(nèi)部服務(wù)是可靠的,并且是始終可用的。不允許出現(xiàn)服務(wù)調(diào)用超時(shí)和重試,將會(huì)對(duì)應(yīng)用程序 的穩(wěn)定性和性能造成不利地影響。需要進(jìn)行適當(dāng)?shù)姆?wù)中斷測(cè)試。這一點(diǎn)十分重要,因?yàn)槿缃竦膽?yīng)用程序多是分布式并且面向服務(wù)的,都需要大量的網(wǎng)絡(luò)服務(wù)。無(wú)限 地請(qǐng)求不可用的服務(wù)會(huì)損害應(yīng)用程序。也需要對(duì)負(fù)載均衡器進(jìn)行測(cè)試,以確保它能正常工作,使每個(gè)節(jié)點(diǎn)達(dá)到平衡。
4、沒(méi)有遵循最低限度的安全要求。正如上文提到,網(wǎng) 絡(luò)服務(wù)隨處可見(jiàn),從而使得黑客可以輕易地利用它進(jìn)行拒絕服務(wù)攻擊。所以,在使用安全套接層時(shí),必須完成基本的驗(yàn)證并使用Google skipfish等工具進(jìn)行滲透測(cè)試。不安全的應(yīng)用程序不僅會(huì)威脅其自身穩(wěn)定性,還可能會(huì)因?yàn)閿?shù)據(jù)完整性問(wèn)題對(duì)公司的聲譽(yù)造成負(fù)面影響,例如出現(xiàn)了客戶(hù) “A”可以瀏覽客戶(hù)“B”數(shù)據(jù)的情況。
5、沒(méi)有進(jìn)行跨瀏覽器的兼容性測(cè)試。如今的網(wǎng)絡(luò)應(yīng)用程序多是豐富的單頁(yè)應(yīng)用程序,它們使用JavaScript編程語(yǔ)言以及angular js這樣的框架。為了使你建設(shè)的網(wǎng)站能夠流暢地運(yùn)行于不同的設(shè)備和瀏覽器之間,必須實(shí)現(xiàn)與之對(duì)應(yīng)的設(shè)計(jì)。所以為了確保你的應(yīng)用程序可以適用于所有設(shè)備和瀏 覽器,必須對(duì)其進(jìn)行兼容性測(cè)試。
6、沒(méi)有外化可能經(jīng)常發(fā)生變化的商業(yè)規(guī)則。例如稅法、政府或行業(yè)相關(guān)要求、分類(lèi)法等。可以使用像Drools這樣的引擎來(lái)處理商業(yè)規(guī)則,它幫助你通過(guò)存入數(shù)據(jù)庫(kù)或 excel的形式,來(lái)外化這些商業(yè)規(guī)則。企業(yè)掌握了這些商業(yè)規(guī)則,就能以最少的變化和測(cè)試完成對(duì)稅法或相關(guān)要求地快速反應(yīng)。
7、沒(méi)有提供下列文檔編寫(xiě)單元測(cè)試文檔并使其擁有良好的代碼覆蓋率。
集成測(cè)試。
一個(gè)綜合的或者百科全書(shū)式的頁(yè)面列出了所有的軟件構(gòu)件,比如類(lèi)、腳本、配置文件等,而這些構(gòu)件要么是被修改了的,要么是新創(chuàng)建的。
高層次的概念圖描述了所有的組件,交互和結(jié)構(gòu)。
而基礎(chǔ)文檔則告訴開(kāi)發(fā)者“如何結(jié)合數(shù)據(jù)源的詳細(xì)信息來(lái)搭建開(kāi)發(fā)環(huán)境”。
除了COS(滿(mǎn)足的條件)這種由MindMap創(chuàng)建的形式之外,
敏捷開(kāi)發(fā)
中還有1和2這兩種主要的文檔形式。
在項(xiàng)目截止日期來(lái)臨之際,常常因?yàn)榧庇诓渴痦?xiàng)目而遺漏了這些事項(xiàng)。沒(méi)有通過(guò)Nagios和Splunk建立合適的系統(tǒng)監(jiān)視機(jī)制不僅會(huì)威脅到應(yīng)用程序的穩(wěn)定性,還會(huì)妨礙目前的診斷和將來(lái)的改進(jìn)工作。
9、沒(méi)有為數(shù)據(jù)庫(kù)表設(shè)計(jì)方便整理的列比如created_datetm、update_datetm、created_by、updated_by和時(shí)間戳,也沒(méi)有提供有條理的刪除記錄列,如可以取‘Y’或‘N’的‘deleted’列或是可以取‘Active’或‘Inactive’的 ‘record_status’列。
10、沒(méi)有制定適當(dāng)?shù)幕爻酚?jì)劃。導(dǎo)致在系統(tǒng)發(fā)生故障時(shí),沒(méi)有辦法將系統(tǒng)恢復(fù)到部署前的穩(wěn)定狀態(tài)。這個(gè)計(jì)劃需要反復(fù)推敲并有相關(guān)團(tuán)隊(duì)簽字保證。計(jì)劃包括了,退回到軟件先前的版本,去除插入到數(shù)據(jù)庫(kù)中的所有數(shù)據(jù)以及屬性文件的所有條目。
11、在項(xiàng)目開(kāi)始前沒(méi)有制定能力計(jì)劃。現(xiàn)如今,在說(shuō)明對(duì)平臺(tái)的要求時(shí),僅僅說(shuō)“需要一臺(tái)Unix計(jì)算機(jī),一個(gè)Oracle數(shù)據(jù)庫(kù)服務(wù)器,一個(gè)JBoss應(yīng)用程序服務(wù)器”是遠(yuǎn)遠(yuǎn)不夠的。你的要求必須精確到
操作系統(tǒng)的特定版本,JVM等。
有多少內(nèi)存(包括物理內(nèi)存,JVM堆內(nèi)存,JVM棧內(nèi)存和JVM永久代的空間)。
CPU(內(nèi)核數(shù))。
負(fù)載均衡器,需要的節(jié)點(diǎn)數(shù)、節(jié)點(diǎn)類(lèi)型,比如是active/active型還是active/passive型,以及聚類(lèi)要求。
文件系統(tǒng)要求,例如,你的應(yīng)用程序可能會(huì)收集生成的報(bào)告并將其保存一年,之后 才進(jìn)行歸檔。這樣的話(huà),你就需要有足夠的硬盤(pán)空間。有些應(yīng)用程序要求產(chǎn)生數(shù)據(jù)提取文件,并將它們暫時(shí)儲(chǔ)存以供其他系統(tǒng)進(jìn)程或數(shù)據(jù)倉(cāng)庫(kù)系統(tǒng)用來(lái)做多維分析報(bào) 告。還有些數(shù)據(jù)文件是基于安全文件傳輸協(xié)議的,它們或來(lái)自?xún)?nèi)部系統(tǒng),或來(lái)自外部系統(tǒng),并且在歸檔前需要被保存12到36個(gè)月。
下面的12來(lái)自“David DeCesare”發(fā)自“java.dzone”的評(píng)論:
12、“不在工作時(shí)使用最好的工具”。很多情況下,開(kāi)發(fā)者會(huì)在生產(chǎn)系統(tǒng)中使用一門(mén)想要學(xué)習(xí)的語(yǔ)言或某種工具。通常這不是最好的選擇。比如,為已經(jīng)實(shí)際上是關(guān)系型的數(shù)據(jù)使用NoSQL數(shù)據(jù)庫(kù)。請(qǐng)記住,無(wú)論你采用哪種工具,都需要在未來(lái)3到5年(甚至更長(zhǎng)的時(shí)期)內(nèi)維護(hù)你的產(chǎn)品。
13、在16個(gè)關(guān)鍵技術(shù)領(lǐng)域缺少充足的知識(shí)儲(chǔ)備。這些領(lǐng)域包括識(shí)別并修復(fù)1)“并發(fā)問(wèn)題”、2)事務(wù)問(wèn)題、3)性能問(wèn)題。很多次面試中,我靠著這3個(gè)方面的知識(shí)拿到了新的合同。
原文鏈接: dzone 翻譯: ImportNew.com - rookie_sam
譯文鏈接: http://www.importnew.com/15346.html
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/64290.html
摘要:如果看視頻能夠成為高手,那每一個(gè)球迷都應(yīng)該是梅西。克服心理障礙前端的飛速發(fā)展,不僅僅是初學(xué)者,哪怕熟手都會(huì)焦慮感覺(jué)很多東西都不會(huì)。 很多前端都想找一個(gè)學(xué)習(xí)計(jì)劃,然后認(rèn)真學(xué),成為一個(gè)大牛;他們迫切的想知道自己該學(xué)什么,然后看什么書(shū),有什么資源可以用! 我今天要告訴你的是,你不要看什么書(shū),不要做什么事!因?yàn)槿绻阍俨磺‘?dāng)?shù)碾A段,看了那些看起來(lái)很正確的金科玉律一般的書(shū)籍,除了打消你學(xué)習(xí)的興趣...
摘要:第條盡量少使用全局對(duì)象避免聲明全局變量盡量聲明局部變量避免對(duì)全局變量增加屬性第條始終聲明局部變量第條避免使用語(yǔ)句第條熟練使用閉包的函數(shù)值包含了比調(diào)用他們時(shí)執(zhí)行所需要的代碼還要更多的信息。那些在其所涵蓋的作用域內(nèi)跟蹤變量的函數(shù)稱(chēng)為閉包。 書(shū)還沒(méi)看完。一遍看,一遍寫(xiě)讀書(shū)筆記。 這本書(shū)的序是JavaScript之父Brendan Eich寫(xiě)的,作者是JavaScript標(biāo)準(zhǔn)化委員會(huì)專(zhuān)家。可想...
摘要:下面我們看看使用可變默認(rèn)參數(shù)時(shí)會(huì)出現(xiàn)什么莫名其妙的狀況。這就意味著如果你使用可變默認(rèn)參數(shù)并改變它,所有調(diào)用該函數(shù)的結(jié)果都是這個(gè)可變對(duì)象。同時(shí)也有注意,該函數(shù)要傳遞一個(gè)對(duì)象作為第二個(gè)參數(shù),因?yàn)楹瘮?shù)中對(duì)它進(jìn)行了操作。 showImg(https://segmentfault.com/img/bVbrFS3?w=762&h=505); 絕大多數(shù)情況下,Python是一個(gè)干凈具有一致性的語(yǔ)言。...
摘要:且可以使用進(jìn)行中文保存,是因?yàn)槭褂眠@種進(jìn)制的編碼。那么怎么解決呢看出來(lái)區(qū)別了嗎由于的自動(dòng)類(lèi)型轉(zhuǎn)換,會(huì)轉(zhuǎn)換為類(lèi)型,所以數(shù)據(jù)溢出的問(wèn)題就解決了。除非到不得已情況,不然不要輕易使用強(qiáng)制類(lèi)型轉(zhuǎn)換。 Java語(yǔ)言中對(duì)于數(shù)據(jù)類(lèi)型分為2種 基本數(shù)據(jù)類(lèi)型(一些具體的數(shù)字單元,例如 1 、 1.1、) 數(shù)值型: 整形:byte、 short、int、 long -->默認(rèn)值:0 浮點(diǎn)型 ...
摘要:來(lái)源前條來(lái)源一書(shū)英文版已經(jīng)出版,這本書(shū)的第二版想必很多人都讀過(guò),號(hào)稱(chēng)四大名著之一,不過(guò)第二版年出版,到現(xiàn)在已經(jīng)將近年的時(shí)間,但隨著,,,甚至的發(fā)布,語(yǔ)言發(fā)生了深刻的變化。譯者在這里第一時(shí)間翻譯成中文版。供大家學(xué)習(xí)分享之用。 來(lái)源:sjsdfg/effective-java-3rd-chinese前 51 條來(lái)源:Effective Java, Third Edition 《Effec...
閱讀 2077·2023-04-25 21:11
閱讀 2966·2021-09-30 09:47
閱讀 2277·2021-09-24 09:48
閱讀 4434·2021-08-23 09:43
閱讀 899·2019-08-30 15:54
閱讀 566·2019-08-28 18:01
閱讀 1402·2019-08-27 10:55
閱讀 591·2019-08-27 10:55