你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

i042416發表於2019-03-10

最近Jerry在忙一個專案,技術棧換成了nodejs平臺,語言換成了JavaScript,因為趕專案進度,一直沒時間更新公眾號。感謝大家的支援,關注人數還是慢慢地增長到了3000。

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

今天我們來聊聊一個比較輕鬆的話題。

當今這個數字化時代,大家的生活都離不開網際網路。網際網路公司為了確保伺服器不會因為軟硬體問題當機而影響自己的業務,紛紛使出渾身解數,包括設計更健壯的架構,實現高質量的程式碼,提供硬體條件更好的機房等。當然也有一些腦洞大開的公司,另闢蹊徑,採取讓佛祖對伺服器進行開光的方式,來實現" 伺服器永不當機 "的美好願望。

下面是Jerry從一則搜狐新聞上看到的一些有趣的圖片,轉貼於此,新聞原文網址:

有請高僧給伺服器貼上靈符:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧
你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

看著這個符咒,Jerry想起了自己曾經通關過無數遍的仙劍奇俠傳98柔情版裡各種各樣的靈符。

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

高僧正在認真地進行開光儀式:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

這些難道是IT管理員,或者SAP稱呼的Basis們,虔誠地跪在伺服器前向佛祖祈禱“ 永不當機 ”嗎?

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧
你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

除了“ 永不當機 ”外,“ 永無bug ”也是程式設計師們另一個美好的願望。

於是乎,有些程式設計師希望透過在程式碼頭部加上這種註釋,來獲得一些心理上的慰藉。

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

而對於SAP ABAP程式設計師,一看到bug這個詞,最容易聯想到什麼?不知道大家心中的答案是什麼,Jerry的答案是: ST22

ABAP程式在執行時,如果遇到了沒有捕捉的異常,程式會終止,同時ABAP執行時會產生一個類似Windows系統藍色畫面的core dump:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

這種dump可以在事務碼ST22裡檢視。一般來說,一個有經驗的ABAP程式設計師,透過分析ST22裡提供的程式崩潰時的上下文資訊,系統變數的內容,呼叫棧等等,不難修復這種bug。

下圖是ST22裡dump的一個例子,值得一提的是大家可能會忽略的BASIS Developer View, 裡面包含了引起執行時錯誤的ABAP語句對應的C語言實現的具體檔案位置,比如下圖的 //bas/753_STACK/src/krn/abap/runt/abassert.c

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

大家還記得我寫過的 聊聊C語言和ABAP  這篇文章麼?

這裡我偷個懶,把那篇文章裡介紹C語言和ABAP語言關係的文字引用過來:

為什麼這篇文章要把C語言和ABAP放在一起講,而不是別的語言比如Java和ABAP呢?因為ABAP語言底層是基於C/C++實現的,包括其關鍵字(比如最簡單的關鍵字WRITE的C++實現有2千多行)和虛擬機器(ABAP Runtime)。SAP內部的一群電腦科學家們發明了ABAP這門偉大的語言,由它實現的各種SAP應用幫助了全球超過180個國家和地區的客戶們更好地執行其業務。

透過Google我們能搜尋到一些關於這些SAP電腦科學家們的介紹,比如這個連結:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

SAP內部的Netweaver開發伺服器上是能夠瀏覽這些C語言程式碼的。Jerry 2017年在德國工作時,業餘時間比較多,相關的C程式碼也閱讀了不少,比如ABAP裡最簡單的WRITE關鍵字,其C語言實現有2000多行。可惜因為這些C語言實現對客戶和partner不可見,因此無法在這裡給大家分享它們的邏輯。

再回到ST22。相信每一位ABAP程式設計師執行程式碼看到ST22的dump後,心裡都會很沮喪。這個時候,如果有佛祖能夠給引起bug的程式碼開開光,那將是一件很鼓舞人心的事情。

相信無論使用何種程式語言的程式設計師,看到下圖紅色高亮的這兩行字,都會精神為之一振:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧
  • 佛祖保佑,永無bug

  • 這段程式碼佛祖已經做過開光處理,絕無可能再產生bug

如何實現ST22裡這個顯示效果?其實ST22和Windows系統藍色畫面顯示邏輯一樣,都是一段靜態模板文字加上執行時異常的實際動態內容合併而成。

模板文字儲存在ABAP Netweaver伺服器的資料庫表裡。我們只需要在ST22的框架程式碼把模板文字從資料庫表讀出之後,將佛祖開光的文字動態新增到模板文字的頭部,就大功告成了。

實現步驟非常簡單,在ST22標準程式 SAPMS380 的subroutine  read_snapt 內建立一個 隱式增強

從read_snapt的程式碼能看出ST22的模板文字是儲存在資料庫表 SNAPT 裡的。

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

把佛祖開光的文字注入到read_snapt輸出的頭部:

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧
你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

這段隱式增強的程式碼我放在了我的Github上:

最終效果就是每次出現了執行時程式執行錯誤後,程式設計師到ST22裡檢視dump時,總能看到“ 佛祖保佑,永無BUG ”幾個字。

這個例子其實也再次體現了Jerry之前提到的,作為 ABAP開發環境和執行環境和二而一的Netweaver ,給開發者提供了強大的可擴充套件性。

最後也是最重要的

1. 本文提供的步驟涉及到了對ABAP框架程式碼的隱式增強,請謹慎使用。禁止在測試伺服器和生產伺服器使用! 否則由此造成的一切負面後果,Jerry本人及SAP概不負責。

2. 如果真的想確保自己交付的程式碼“ 永無BUG ”,程式設計師還是得老老實實練好自己的內功,而不要把自己的命運交給佛祖。畢竟國內這麼多程式設計師,這麼多行程式碼,要是每一位程式設計師每一行程式碼都要由佛祖開光,佛祖得多累鴨,佛祖忙不過來鴨!

你的ABAP程式給佛祖開過光麼?來試試Jerry這個小技巧

更多閱讀


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2637985/,如需轉載,請註明出處,否則將追究法律責任。

相關文章