生產過程中出現的問題正逐漸得到中階和最高管理階層的重視。不管是身為開發人員還是架構師,下列的事項都應該得到你足夠的重視以避免陷入未來的尷尬境地。你也可以把它當作排查問題的便條紙。
#1、不在屬性檔案或 XML 檔案中外化配置屬性。例如,沒有把批次使用的執行緒數設定成可在屬性檔中配置。你的批次程式無論在DEV 環境中,還是UAT(使用者驗收測試)環境中,都可以順暢無阻地運行,但是一旦部署在PROD 上,把它作為多執行緒程式處理更大的資料集時,就會拋出IOException,原因可能是JDBC 驅動程式版本不同,也可能是#2 中討論的問題。如果執行緒數目可以在屬性檔中配置,那麼使它成為一個單執行緒應用程式就變得十分容易了。我們不再需要為了解決問題而重複部署和測試應用程式了。這種方法也同樣適用於設定 URL、伺服器和連接埠號碼等。
#2、測試中使用的資料集規模不合適。例如,生產過程中一個典型的場景就是只使用 1 到 3 個帳戶進行測試,而這個數量本應是 1000 到 2000 個的。在做效能測試時,使用的資料必須是真實且未經裁剪的。不貼近真實環境的效能測試,可能會帶來不可預測的效能、拓展和多執行緒問題。只有使用更大規模的資料集對應用程式進行測試,才能保證它正常運作並滿足非功能屬性的 SLAs(服務等級標準)。
#3、天真地認為應用程式中所呼叫的外部和內部服務是可靠的,並且是始終可用的。不允許出現服務呼叫逾時和重試,將會對應用程式的穩定性和效能造成不利地影響。需要進行適當的服務中斷測試。這一點十分重要,因為如今的應用程式多是分散式且面向服務的,都需要大量的網路服務。無限地請求不可用的服務會損害應用程式。也需要對負載平衡器進行測試,以確保它能正常運作,使每個節點達到平衡。
#4、沒有遵循最低限度的安全要求。如上文提到,網路服務隨處可見,使得駭客可以輕易地利用它進行拒絕服務攻擊。所以,在使用安全通訊端時,必須完成基本的驗證並使用 Google skipfish 等工具進行滲透測試。不安全的應用程式不僅會威脅其自身穩定性,還可能因為資料完整性問題對公司的聲譽造成負面影響,例如出現了客戶 “A”可以瀏覽客戶“B”資料的情況。
#5、沒有進行跨瀏覽器的相容性測試。如今的網頁應用程式大多是豐富的單頁應用程序,它們使用 JavaScript 程式語言以及 angular js 這樣的框架。為了使你建造的網站能夠流暢地運行於不同的設備和瀏覽器之間,必須實現與之對應的設計。所以為了確保你的應用程式可以適用於所有裝置和瀏覽器,必須對其進行相容性測試。
#6、沒有外化可能經常改變的商業規則。例如稅法、政府或產業相關要求、分類法等。可以使用像 Drools 這樣的引擎來處理商業規則,它幫助你透過存入資料庫或 excel 的形式,來外化這些商業規則。企業掌握了這些商業規則,就能以最少的變化和測試完成對稅法或相關要求地快速反應。
#7、沒有提供下列文件
編寫單元測試文件並使其擁有良好的程式碼覆蓋率。
整合測試。
一個綜合的或百科全書式的頁面列出了所有的軟體構件,例如類別、腳本、設定檔等,而這些構件要麼是被修改了的,要麼是新創建的。
高層次的概念圖描述了所有的組件,互動和結構。
而基礎文件則告訴開發者「如何結合資料來源的詳細資訊來建立開發環境」。
除了 COS(滿足的條件)這種由 MindMap 創建的形式之外,敏捷開發中還有 1 和 2 這兩種主要的文檔形式。
#8、沒有適當的災害復原計畫、系統監視和歸檔策略。在專案截止日期來臨之際,常常因為急於部署專案而遺漏了這些事項。沒有透過 Nagios 和 Splunk 建立合適的系統監視機制不僅會威脅到應用程式的穩定性,還會妨礙目前的診斷和將來的改進工作。
#9、沒有為資料庫表設計方便整理的列,例如created_datetm、update_datetm、created_by、updated_by 和時間戳,也沒有提供有條理的刪除記錄列,如可以取'Y'或'N'的'deleted '列或是可以取'Active'或'Inactive'的'record_status'欄位。
#10、沒有製定適當的回撤計畫。導致系統故障時,沒有辦法將系統恢復到部署前的穩定狀態。這個計劃需要反覆推敲並有相關團隊簽署保證。計劃包括了,退回到軟體先前的版本,去除插入到資料庫中的所有資料以及屬性檔案的所有條目。
#11、在專案開始前沒有製定能力計畫。現如今,在說明對平台的要求時,僅僅說「需要一台 Unix 計算機,一個 Oracle 資料庫伺服器,一個 JBoss 應用程式伺服器」是遠遠不夠的。你的要求必須精確到
作業系統的特定版本,JVM 等。
有多少內存(包括物理內存,JVM 堆內存,JVM 棧內存和 JVM 永久代的空間)。
CPU(核心數)。
負載平衡器,需要的節點數、節點類型,例如是 active/active 型還是 active/passive 型,以及聚類要求。
檔案系統要求,例如,你的應用程式可能會收集產生的報告並將其保存一年,之後才進行歸檔。這樣的話,你就需要有足夠的硬碟空間。有些應用程式要求產生資料擷取文件,並將它們暫時儲存以供其他系統進程或資料倉儲系統用來做多維分析報告。還有一些資料檔案是基於安全文件傳輸協定的,它們或來自內部系統,或來自外部系統,並且在歸檔前需要被保存 12 到 36 個月。
下面的#12來自“David DeCesare”發自“java.dzone”的評論,
#12、“不在工作時使用最好的工具”。很多情況下,開發者會在生產系統中使用想要學習的語言或某種工具。通常這不是最好的選擇。例如,為已經實際上是關係型的資料使用 NoSQL 資料庫。請記住,無論你採用哪種工具,都需要在未來 3 到 5 年(甚至更長的時期)內維護你的產品。
#13、在 16 個關鍵技術領域缺乏充足的知識儲備。這些領域包括識別並修復1)「並發問題」、2)事務問題、3)效能問題。在很多次面試中,我靠著這 3 個方面的知識拿到了新的合約。

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

本文解釋了用於構建分佈式應用程序的Java的遠程方法調用(RMI)。 它詳細介紹了接口定義,實現,註冊表設置和客戶端調用,以解決網絡問題和安全性等挑戰。

本文詳細介紹了用於網絡通信的Java的套接字API,涵蓋了客戶服務器設置,數據處理和關鍵考慮因素,例如資源管理,錯誤處理和安全性。 它還探索了性能優化技術,我

本文詳細介紹了創建自定義Java網絡協議。 它涵蓋協議定義(數據結構,框架,錯誤處理,版本控制),實現(使用插座),數據序列化和最佳實踐(效率,安全性,維護


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中