如何提升大型機性能參考

來源:文萃谷 2.36W

減少大型機CPU消耗是個重要工作。節約每個CPU週期,不僅可以延緩硬件升級,還可以降低基於使用規模的軟件授權費。

如何提升大型機性能參考

IBM Language Environment (LE)編輯器和運行時提供了很多優化選項——從而無須修改源代碼。

編譯時間選項

通過LE編譯器優化,大型機程序員可以調整目標代碼,充分發揮某個處理器家族計算性能。

ARCH(架構)是一個編輯器選項。ARCH級會指示編譯器生成含有針對目標處理器進行性能優化的機器指令目標代碼。ARCH重要性日益增加,因為IBM已經推出了數代服務器,都包含了針對性能優化設計的指令集。

另一種選擇是TUNE,告訴編輯器安排機器指令順序,確保能夠利用處理器的指令管道與緩存優勢。

程序員需要為生產線上最古老的處理器系列進行優化。挑錯ARCH選項,並且操作異常(0C1s)可能會導致壞的TUNE,並降低性能。

雖然這些選項通常來説只專門針對C++編譯器,但IBM已經將其擴展到COBOL與PL/1高級語言

運行時選項

IBM lE同樣提供了多種運行時選項,可以提高大型機性能。

以下是選項指定的層次結構:

運行時選項在程序中調用中指定

使用用户選項(UOPT)控制會話(CSECT)連接選項到程序

區域選秀(ROPT)模塊

CEEPRMxx ParmLIB成員中的全局選項集

CBLPSHOPOPS的常規處理條件,存儲初始化與堆棧大小是運行時優化選項,尤其在CICS環境中。

CBLPSHPOPS。CBPSHPOPS控制LE在進入或退出COBOL運行時時,是否執行PUSH HANDLE與POP HANDLE CICS命令。PUSH HANDLE命令PUSH HANDLE命令用棧保存所有尚未處理的條件,而POP則將句柄條件從前推動。如果任何條件在有未處理句柄的情況下被提出,那麼控制會切換到HANDLE命令指定的錯誤運行時。

關閉CBPSHPOPS選項可以節約CPU週期,避免額外的'PUSH與POP命令。然而,如果沒有CBPSHPOPS,在較低模塊提出的條件可能會滲透到沒有錯誤準備的高級處理運行時。只有在分析與測試後才改變配置。

存儲初始化 。STORAGE選項通一些參數控制內存初始化,例如新申請的堆段參數,LE釋放的堆段參數以及初始化棧或當控制進入運行時進行自動存儲。

堆初始化往往是CPU週期方面最廉價的成本。初始化棧存儲則更昂貴,雖然成本取決於子程序調用次數。除非你為國家安全局工作,否則不要使用erase-on-free 清除選項。

要避免LE內存共同初始化,遵循編程最佳實踐,假定存儲是為初始化的,除非在程序中有另外明確指出。

棧和堆大小 。LE有自己的內存管理器,其目的是減少程序找操作系統或CICS申請更多存儲的次數。 LE在大塊中獲得內存,再根據需要細分。當塊無法滿足存儲要求時, LE會調用操作系統或CICS申請另一個塊。一個初始化堆或棧存儲的明智選擇將減少調用操作系統內存管理次數並降低CPU使用率。

選擇初始塊大小時一門超越科學的藝術。分塊過小會增加CPU使用,但分塊過大可能會降低存儲使用。

在大存儲塊中的碎片在混合應用程序中相當麻煩。對於一個虛擬的應用程序,某程序從對存儲塊中申請512KB大小的堆,而另一個程序可能會在相同時間申請從1MB堆塊中獲得32字節的堆。隨着程序運行,第一個程序獲得512KB並調用另外那個獲得32字節的程序。當第一個程序試圖獲得512KB時,LE無法通過現有的塊滿足需求,而必須申請另外一個塊。這意味着有幾乎0.5MB的存儲沒有被使用。

在選擇初始堆和棧大小時,先研究應用程序行為。同樣為CICS在每個用户存儲分段的開頭與結尾設置8字節“崩潰區”。一個4-K IBM LE事務請求(GETMAIN)實際佔用4,112字節,這將導致CICS存儲碎片。堆CICS來説,使用4,080字節,非常適合一個4-K頁。LE同樣使用一些新的存儲用來滿足自己使用控制,這也進一步降低了留給程序的可用空間。

熱門標籤