達夢數據庫-數據文件 (二)

達夢數據庫-數據文件(二)-自動監控達夢數據庫表空間使用率的 Shell 腳本

自動監控達夢數據庫表空間使用率的 Shell 腳本,支持:

  • ? 實時計算每個表空間的使用率
  • ? 設置閾值告警(如 >80%)
  • ? 支持郵件告警(可選)
  • ? 日志記錄
  • ? 可集成到定時任務(crontab)

📄 腳本名稱:check_dameng_tablespace.sh

#!/bin/bash# ========================================
# 達夢數據庫表空間使用率監控腳本
# 功能:檢查表空間使用率,超閾值發送告警
# 作者:DBA
# ========================================# ====== 用戶可配置區 ======
DM_HOME="/dm8"
BIN_DIR="$DM_HOME/bin"
DISQL="$BIN_DIR/disql"
DATA_DIR="/dm8/data/DAMENG"# 數據庫連接
SYS_USER="SYSDBA"
SYS_PWD="SYSDBA"
DB_PORT="5236"
DB_HOST="localhost"# 告警閾值(百分比)
WARNING_THRESHOLD=80    # 警告
CRITICAL_THRESHOLD=95   # 嚴重# 郵件配置(可選)
ENABLE_EMAIL=false      # 是否啟用郵件告警
SMTP_SERVER="smtp.company.com"
SMTP_PORT="587"
FROM_EMAIL="db-monitor@company.com"
TO_EMAIL="dba@company.com"# 日志文件
LOG_FILE="/tmp/dm_tablespace_monitor.log"
# ==========================# 日志函數
log_info() {echo "[$(date +'%Y-%m-%d %H:%M:%S')] INFO: $*" | tee -a "$LOG_FILE"
}log_warn() {echo "[$(date +'%Y-%m-%d %H:%M:%S')] WARN: $*" | tee -a "$LOG_FILE"
}log_crit() {echo "[$(date +'%Y-%m-%d %H:%M:%S')] CRITICAL: $*" | tee -a "$LOG_FILE"
}# 發送郵件函數(使用 mailx)
send_alert() {local subject="$1"local body="$2"if $ENABLE_EMAIL; thenecho "$body" | mailx -v -s "$subject" \-S smtp="$SMTP_SERVER:$SMTP_PORT" \-S from="$FROM_EMAIL" \"$TO_EMAIL"log_info "告警郵件已發送: $subject"elselog_info "郵件未啟用,告警內容: $subject"fi
}# 檢查數據庫是否可達
if ! $DISQL $SYS_USER/$SYS_PWD@$DB_HOST:$DB_PORT << EOF > /dev/null 2>&1
SELECT 1 FROM DUAL;
EXIT
EOF
thenlog_crit "數據庫連接失敗!請檢查實例狀態"send_alert "【嚴重】達夢數據庫連接失敗" "無法連接到達夢數據庫,請立即檢查!"exit 1
fi# 執行 SQL 查詢表空間使用情況
SQL_QUERY="
SET HEADING OFF;
SET FEEDBACK OFF;
SET PAGESIZE 0;
SELECT TBS.TABLESPACE_NAME,ROUND(TBS.TOTAL_MB, 2) AS TOTAL_MB,ROUND(TBS.USED_MB, 2) AS USED_MB,ROUND(TBS.USED_MB / TBS.TOTAL_MB * 100, 2) AS PCT_USED
FROM (SELECT TABLESPACE_NAME,SUM(BYTES)/1024/1024 AS TOTAL_MB,SUM(USER_BYTES)/1024/1024 AS USED_MBFROM DBA_DATA_FILES GROUP BY TABLESPACE_NAME
) TBS
ORDER BY PCT_USED DESC;
EXIT;
"# 執行查詢
RESULT_FILE=$(mktemp)
$DISQL $SYS_USER/$SYS_PWD@$DB_HOST:$DB_PORT << EOF > "$RESULT_FILE"
$SQL_QUERY
EOF# 解析結果并檢查閾值
CRITICAL_ALERT=""
WARNING_ALERT=""while IFS=' ' read -r name total_mb used_mb pct_used; do# 跳過空行或標題if [[ -z "$name" || "$name" == "TABLESPACE_NAME" ]]; thencontinuefi# 移除可能的回車符pct_used=$(echo "$pct_used" | tr -d '\r')# 必須是數字才處理if ! [[ "$pct_used" =~ ^[0-9]+\.?[0-9]*$ ]]; thencontinuefilog_info "表空間: $name, 大小: ${total_mb}MB, 已用: ${used_mb}MB, 使用率: ${pct_used}%"if (( $(echo "$pct_used > $CRITICAL_THRESHOLD" | bc -l) )); thenCRITICAL_ALERT="$CRITICAL_ALERT\n表空間 [$name] 使用率 ${pct_used}% (>${CRITICAL_THRESHOLD}%)"elif (( $(echo "$pct_used > $WARNING_THRESHOLD" | bc -l) )); thenWARNING_ALERT="$WARNING_ALERT\n表空間 [$name] 使用率 ${pct_used}% (>${WARNING_THRESHOLD}%)"fi
done < "$RESULT_FILE"# 發送告警
if [ -n "$CRITICAL_ALERT" ]; thenMSG="【嚴重告警】達夢表空間使用率過高!$CRITICAL_ALERT"log_crit "$MSG"send_alert "【嚴重】達夢表空間使用率過高" "$MSG"
elif [ -n "$WARNING_ALERT" ]; thenMSG="【警告】達夢表空間使用率偏高!$WARNING_ALERT"log_warn "$MSG"send_alert "【警告】達夢表空間使用率偏高" "$MSG"
elselog_info "所有表空間使用率正常(<${WARNING_THRESHOLD}%)"
fi# 清理臨時文件
rm -f "$RESULT_FILE"exit 0

🛠? 使用方法

1. 保存腳本

vim /dm8/script/check_dameng_tablespace.sh

2. 授予執行權限

chmod +x /dm8/script/check_dameng_tablespace.sh

3. 安裝依賴(如果未安裝)

# 安裝 bc(用于浮點比較)
sudo yum install -y bc# 安裝 mailx(用于郵件)
sudo yum install -y mailx

4. 測試腳本

/dm8/script/check_dameng_tablespace.sh

🕒 添加到定時任務(crontab)

每 30 分鐘檢查一次:

crontab -e# 添加以下行
*/30 * * * * /dm8/script/check_dameng_tablespace.sh

? 腳本功能說明

功能說明
? 自動連接數據庫使用 disql 查詢 DBA_DATA_FILES
? 計算使用率按表空間匯總,精確到小數點后兩位
? 分級告警警告(80%)、嚴重(95%)
? 日志記錄記錄到 /tmp/dm_tablespace_monitor.log
? 郵件告警可選啟用,支持 SMTP
? 臨時文件安全使用 mktemp 創建臨時文件

📧 郵件告警示例

主題【嚴重】達夢表空間使用率過高
內容

【嚴重告警】達夢表空間使用率過高!表空間 [DMHR] 使用率 99.9%
表空間 [TEMP] 使用率 96.2%

? 建議配置

項目建議值
WARNING_THRESHOLD80
CRITICAL_THRESHOLD95
ENABLE_EMAILtrue(生產環境)
TO_EMAILDBA 郵箱或運維群組

📊 輸出示例(日志)

[2025-08-28 10:30:01] INFO: 表空間: DMHR, 大小: 228.00MB, 已用: 227.80MB, 使用率: 99.91%
[2025-08-28 10:30:01] CRITICAL: 【嚴重告警】達夢表空間使用率過高!
表空間 [DMHR] 使用率 99.91% (>95%)

🚀 進階建議

  1. 集成到 Zabbix/Prometheus:將輸出轉為 JSON,用于可視化監控
  2. 自動擴容:檢測到空間不足時,自動執行 ALTER TABLESPACE ADD DATAFILE
  3. 歷史趨勢分析:將結果寫入數據庫,生成趨勢圖

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/94911.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/94911.shtml
英文地址,請注明出處:http://en.pswp.cn/web/94911.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何用 Android 平臺開發第一個 Kotlin 小程序

安裝開發環境下載并安裝最新版 Android Studio&#xff08;官方 IDE&#xff09;&#xff0c;安裝時勾選 Kotlin 插件。確保 JDK 版本為 11 或更高。創建新項目打開 Android Studio 選擇 File > New > New Project&#xff0c;選擇 Empty Activity 模板。在配置界面中&am…

Java常用工具類

異常 (Exception)。程序世界并非總是完美的&#xff0c;異常處理機制就是Java為我們提供的優雅應對錯誤的解決方案。一、為什么需要異常處理&#xff1f;—— 從現實世界說起 想象一下現實生活中的場景&#xff1a; 開車上班&#xff1a;你計劃開車去公司&#xff08;正常流程&…

AWS亞馬遜云賬號注冊指南

AWS是全球領先的云計算平臺&#xff0c;提供廣泛的云服務。賬號注冊是開端&#xff0c;不管是用來學習、搭建個人項目&#xff0c;還是公司項目部署上線需要&#xff0c;都需要進行這一步。提醒&#xff1a;在使用賬戶之前&#xff0c;必須要綁定國際的信用卡&#xff1b;通過我…

云計算學習100天-第31天

Keepalived概念keepalived 是Linux下一個輕量級的高可用解決方案主要是通過虛擬路由冗余協議(VRRP)來實現高可用功能Virtual Router Redundancy Protocol起初就是為了補充LVS功能而設計的&#xff0c;用于監控LVS集群內后端真實服務器狀態后來加入了VRRP的功能&#xff0c;它出…

2025年視覺、先進成像和計算機技術論壇(VAICT 2025)

會議簡介 作為人工智能大數據創新發展論壇的重要分論壇&#xff0c;2025年視覺、先進成像和計算機技術論壇聚焦人工智能感知世界的核心前沿&#xff0c;將于2025年9月18-20日在中國廣州廣東科學館舉行。 視覺與成像技術是智能系統理解環境的關鍵&#xff0c;計算機技術則…

MySQL 與 ClickHouse 深度對比:架構、性能與場景選擇指南

&#x1f31f; 引言&#xff1a;數據時代的引擎之爭 在當今數據驅動的企業環境中&#xff0c;選擇合適的數據庫引擎成為架構設計的關鍵決策。想象這樣一個場景&#xff1a;特斯拉的實時車況分析系統需要在毫秒級延遲下處理數百萬輛汽車的傳感器數據&#xff0c;而某電商平臺的訂…

閉包與內存泄漏:深度解析與應對策略

在 JavaScript 編程中&#xff0c;閉包是一個強大且常用的特性&#xff0c;但如果使用不當&#xff0c;可能會引發內存泄漏問題&#xff0c;影響程序性能甚至導致頁面卡頓。本文將深入剖析閉包導致內存泄漏的原理&#xff0c;結合實例講解&#xff0c;并給出切實可行的避免方法…

open webui源碼分析12-Pipeline

Pipeline是 Open WebUI 的一項創新&#xff0c;它 為任何支持 OpenAI API 規范的 UI 客戶端帶來了模塊化、可定制的工作流 —— 甚至更多功能&#xff01;只需幾行代碼&#xff0c;你就能輕松擴展功能、集成自己的專有邏輯并創建動態工作流。 當你處理計算密集型任務&#xff0…

深入解析 Chromium Mojo IPC:跨進程通信原理與源碼實戰

在現代瀏覽器架構中&#xff0c;多進程設計已經成為標配。Chromium 瀏覽器作為典型的多進程瀏覽器&#xff0c;其瀏覽器進程&#xff08;Browser Process&#xff09;、渲染進程&#xff08;Renderer Process&#xff09;、GPU 進程、Utility 進程等之間的通信&#xff0c;依賴…

【自動化測試】測試分類概述-初步接觸自動化測試

&#x1f525;個人主頁&#xff1a; 中草藥 &#x1f525;專欄&#xff1a;【Java】登神長階 史詩般的Java成神之路 測試分類 了解各種各樣的測試方法分類&#xff0c;不是為了墨守成規按照既定方法區測試&#xff0c;而是已了解思維為核心&#xff0c;并了解一些專業名詞 根…

【Python辦公】快速比較Excel文件中任意兩列數據的一致性

目錄 專欄導讀 項目背景 技術選型 核心技術棧 選型理由 功能特性 ?? 核心功能 ?? 輔助功能 架構設計 整體架構 設計模式 核心代碼解析 1. 類初始化和UI設置 2. 文件選擇和數據加載 3. 數據比較核心算法 4. 結果導出功能 界面設計詳解 布局結構 UI組件選擇 性能優化 1. 內存…

nginx的誕生背景、核心優勢、與 Apache 的對比

下面用“3 個 1 分鐘”幫你快速建立 Nginx 的整體印象&#xff1a; 1 分鐘了解它為何誕生&#xff0c;1 分鐘看懂它的 5 大核心優勢&#xff0c;再花 1 分鐘搞清和 Apache 的關鍵差異。誕生背景&#xff08;2002-2004&#xff09; ? 作者&#xff1a;俄羅斯系統工程師 Igor Sy…

算法題打卡力扣第169題:多數元素(easy)

文章目錄題目描述解法一&#xff1a;暴力解解法二 排序法解法三&#xff1a;Boyer-Moore 投票算法 (最優解)題目描述 解法一&#xff1a;暴力解 定義一個數組C用于存放nums數組中每個數出現的次數&#xff0c;然后再遍歷C&#xff0c;判斷C【i】是否大于? n/2 ?&#xff0c;…

A6.0:PCB的設計流程

第一步&#xff1a;導入網表第二步&#xff1a;結構導入和板框定義1.導入結構文件:加載DXF格式的機械結構圖(含板框、定位孔、限高區)&#xff0c;確保元件布局符合物理約束。2.固定器件預放置:將接插件、按鍵、散熱器等結構敏感元件鎖定到指定位置&#xff0c;避免后期調整沖突…

深度學習在金融訂單簿分析與短期市場預測中的應用

金融訂單簿記錄了市場上買賣雙方的委托訂單信息&#xff0c;包括價格、數量、訂單類型等關鍵要素。其數據具有以下特點&#xff1a; 高頻性&#xff1a;訂單在極短時間內不斷產生與變化&#xff0c;數據更新速度極快&#xff0c;每秒可能產生大量新訂單。序列性&#xff1a;訂單…

C++基礎算法——貪心算法

思想&#xff1a;總是做出在當前看來是最好的選擇 例題一、排隊打水問題 n個人&#xff0c;r個水龍頭&#xff0c;花費時間最少的安排&#xff1f;&#xff08;包含等待時間&#xff09; #include<iostream> #include <bits/stdc.h> using namespace std; int ma…

事務和鎖(進階)

事務和鎖&#xff08;進階&#xff09;一.回顧事務1.什么是事務2 為什么要使用事務3 怎么使用事務二.InnoDB和ACID模型三. 如何實現原子性四.如何實現持久性五.隔離性實現原理1.事務的隔離性2.事務的隔離級別3.鎖1&#xff09;鎖信息2&#xff09; 共享鎖和獨占鎖-Shared and E…

【Mentor Xpedition】預習一下

這個軟件不同于一般的PCB設計軟件&#xff0c;采用獨特的中心庫形式&#xff0c;相比cadence的SCH和PCB更緊湊&#xff0c;或者說本就是一家人&#xff0c;不像orcad和allegro強行捆在一起。 基本symbol給原理用&#xff0c;cell給PCB用。

通過代碼認識 CNN:用 PyTorch 實現卷積神經網絡識別手寫數字

目錄 一、從代碼看 CNN 的核心組件 二、準備工作&#xff1a;庫導入與數據加載 三、核心&#xff1a;用代碼實現 CNN 并理解各層作用 1.網絡層結構 2.重點理解&#xff1a;卷積層參數與輸出尺寸計算 四、訓練 CNN 五、結果分析 卷積神經網絡&#xff08;CNN&#xff09;…

基于SpringBoot和Thymeleaf開發的英語學習網站

角色&#xff1a; 管理員、用戶 技術&#xff1a; SpringBoot、Thymeleaf、MySQL、MyBatis、jQuery、Bootstrap 核心功能&#xff1a; 這是一個基于SpringBoot的英語學習平臺&#xff0c;旨在為用戶提供英語學習資料&#xff08;如書籍、聽力、單詞&#xff09;的管理和學習功能…