Linux grep命令與$?命令結合使用技巧

来源:https://www.cnblogs.com/kerrycode/archive/2023/07/13/17552416.html
-Advertisement-
Play Games

今天檢查前同事留下的一個shell腳本時,其中一個腳本中有一個業務邏輯處理:要判斷Oracle資料庫實例是否啟動,如果資料庫實例處於OPEN狀態的話,則執行/運行一些業務邏輯操作。腳本大體如下(腳本做了一下混淆和精簡收縮) up_flag=`${SCRIPT_DIR}/chkdbup.sh ${OR ...


今天檢查前同事留下的一個shell腳本時,其中一個腳本中有一個業務邏輯處理:要判斷Oracle資料庫實例是否啟動,如果資料庫實例處於OPEN狀態的話,則執行/運行一些業務邏輯操作。腳本大體如下(腳本做了一下混淆和精簡收縮)

up_flag=`${SCRIPT_DIR}/chkdbup.sh ${ORACLE_SID}`

if [ ${up_flag} -eq 0 ]; then 
  .......
  exit
else
  .......
fi

其中chkdbup.sh腳本的內容如下:

ps -ef | grep -i smon_${1} | grep -v "grep" >/dev/null 
echo $?

Review這個腳本時,我感覺這個腳本的邏輯有問題(我認為這個腳本存在一個邏輯"bug"),主要是{up_flag}不為0時則表示資料庫實例異常了

if [ ${up_flag} -eq 0 ]; then 
  .......
  exit
else
  .......
fi

在Linux shell腳本中,$?一般表示上一個命令的返回值(執行情況),執行成功,返回0,其他任何數值表示上條命令執行有錯誤。我認為資料庫實例OPEN或關閉或crash的時候,chkdbup.sh這個腳本都會返回0,而不會返回值1,為了驗證我的想法,於是我找了台測試環境驗證測試一下。當前測試環境下ORACLE_SID為kerry

[oracle@mytestdb ~]$ ps -ef | grep -i smon_kerry | grep -v "grep"
oracle   1338965       1  0 Jul05 ?        00:00:14 ora_smon_kerry
[oracle@mytestdb ~]$ echo $?
0

換一個ORACLE_SID,此時因為Oracle實例不存在,就可以模擬實例Crash的情況(懶得關閉Oracle實例了,這個跟關閉Oracle實例測試效果一致)

[oracle@mytestdb ~]$ ps -ef | grep -i smon_gsp | grep -v "grep"
[oracle@mytestdb ~]$ echo $?
1

按照我的想法/認知,不管這個資料庫實例存在或不存在,ps命令總是會執行成功,它就會返回0,而且是永遠返回0,但是測試驗證結果跟我的想法/認知不符合,Why?查了一些資料,然後和同事討論後,終於搞清楚了其中的原因,主要是因為$?命令獲取的上一條命令的返回結果,而上一條命令中使用了grep命令,而grep命令的返回結果是這樣的:如果找到了匹配的相關記錄則返回0,如果沒有找到匹配的相關記錄則返回1,如果執行過程中出錯,就返回2,你可以使用man grep查看相關說明,具體如下所示:

EXIT STATUS
       Normally  the  exit status is 0 if a line is selected, 1 if no lines were selected, and 2 if an error occurred.  However,
       if the -q or --quiet or --silent is used and a line is selected, the exit status is 0 even if an error occurred.

其實,grep命令在HP-UX下也是同樣的返回值,如下所示:

 RETURN VALUE
      Upon completion, grep returns one of the following values:

 Hewlett-Packard Company            - 3 -       HP-UX 11i Version 3 Feb 2007

 grep(1)                                                             grep(1)

           0    One or more matches found.
           1    No match found.
           2    Syntax error or inaccessible file (even if matches were
                found).

所以,我的想法/認知是錯誤的,而前同事也是在shell腳本中藉助grep這個特性和$?來判斷Oracle實例是否處於OPEN狀態。這個也是一個shell腳本中的一個技巧,只是我很少用這種技巧,另外,由於對grep命令返回的值不清楚(具體來說,不清楚grep沒有匹配到相關記錄時返回1)。因此鬧了一個烏龍事件。

掃描上面二維碼關註我 如果你真心覺得文章寫得不錯,而且對你有所幫助,那就不妨幫忙“推薦"一下,您的“推薦”和”打賞“將是我最大的寫作動力! 本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接.
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近用結合thumbnailator和Graphics2D封裝了一個圖片工具類,目前可以實現圖片的裁剪、壓縮、添加圖片水印、文字水印、多行文字水印等功能,同時該工具類的實現使用了建造者模式、責任鏈模式、工廠模式、策略模式等多種設計模式,感覺圖片處理的功能有一定的通用性,所以這次寫一篇文章來分享一下這... ...
  • 博主記得在一個周五快下班的下午,產品找到我(為什麼總感覺周五快下班就來活 😂),跟我說有幾個業務列表查詢需要加上時間條件過濾數據,這個條件可能會變,不保證以後不修改,這個改動涉及到多個列表查詢,於是博主思考了一會想了幾種實現方案, 1. 最簡單,直接將時間條件寫死,由 Service 層傳遞給 D ...
  • 學習數字信號處理演算法時整理的學習筆記。本篇介紹 SSB 單邊帶調幅信號的調製與解調,內附全套 MATLAB 代碼。 ...
  • 解耦 含義 系統各個模塊或組件之間的耦合度降低,使得它們能夠獨立地進行開發、測試、部署和維護。通過解耦,可以提高系統的可維護性、可擴展性和可重用性。 使用場景 將前端和後端分離,通過API介面就行通信,使得前端和後端可以獨立開發、測試和部署。 使用消息隊列解耦生產者和消費者,生產者將消息發送到消息隊 ...
  • JWT簡介 是一種身份認證的開放標準(RFC 7519),可以在網路應用間傳輸信息作為Json對象。由三部分組成:頭部(Header)、載荷(payload)和簽名(Signature). 頭部(Header) 兩部分組成,令牌類型和所使用的的簽名演算法 { "alg":"HS256", "typ": ...
  • 基本概念 是一種用於非同步編程的概念。Task的重要特點是可以在後臺執行方法或操作,而不會阻塞主線程或UI線程。 封裝的非同步操作,表示執行的操作正在進行。可以表示一個方法的返回值或者表示執行的操作已經完成。 Task類的主要成員 屬性:TaskStatus、IsCanceled、IsCompleted ...
  • ## 引言 最近做一個配置的功能,需求是該配置項跟另一個整形配置項關聯,具有一定的函數關係,例如有一個配置項是值為 `N` ,則另一配置 `F` 項滿足函數關係$F=2/(N+1)$。這個函數關係是客戶手動輸入,只需要簡單的四則運算,所以我們要做的就是判斷四則運算表達式是否有效,且給定 `N` 的值 ...
  • 之前在Windows上用過一款圓盤菜單工具Quicker, 感覺非常方便, 換成Macos後,一直沒有找到類似應用。 最近終於發現,一款好用的快捷鍵收集,觸發工具Radial Menu. 其核心功能是可以根據當前程式的上下文,彈出一個圓盤菜單。 執行圓盤中的動作。 目前菜單動作還僅支持快捷鍵,預計後 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...