zioinfo-mail/workspace/guardia-itsm/scripts/sm/esb/esb_check.sh
DESKTOP-TKLFCPR\ython cfe2901a55 refactor(structure): consolidate all projects under workspace/
- itsm/    -> workspace/guardia-itsm/
- manager/ -> workspace/guardia-manager/
- app/     -> workspace/guardia-messenger/
- manual/  -> workspace/guardia-docs/

workspace/zioinfo-web/ unchanged.
git mv preserves full commit history.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 23:50:56 +09:00

218 lines
9.3 KiB
Bash

#!/bin/bash
# ============================================================
# GUARDiA SM | esb_check.sh
# 대상: ESB / MQ (ActiveMQ, IBM MQ, WSO2 ESB/MI)
# 파라미터: ESB_TYPE=activemq|ibmmq|wso2
# ACTIVEMQ_HOME=/opt/activemq ACTIVEMQ_PORT=61616
# ACTIVEMQ_CONSOLE=http://localhost:8161
# IBMMQ_HOME=/opt/mqm MQ_QMGR=QM1 MQ_PORT=1414
# WSO2_HOME=/opt/wso2 WSO2_PORT=8280 WSO2_MGMT_PORT=9443
# QUEUE_DEPTH_WARN=1000
# ============================================================
set -euo pipefail
ESB_TYPE=${ESB_TYPE:-activemq}
ACTIVEMQ_HOME=${ACTIVEMQ_HOME:-/opt/activemq}
ACTIVEMQ_PORT=${ACTIVEMQ_PORT:-61616}
ACTIVEMQ_CONSOLE=${ACTIVEMQ_CONSOLE:-"http://localhost:8161"}
ACTIVEMQ_USER=${ACTIVEMQ_USER:-admin}
ACTIVEMQ_PASS=${ACTIVEMQ_PASS:-admin}
IBMMQ_HOME=${IBMMQ_HOME:-/opt/mqm}
MQ_QMGR=${MQ_QMGR:-QM1}
MQ_PORT=${MQ_PORT:-1414}
WSO2_HOME=${WSO2_HOME:-/opt/wso2}
WSO2_PORT=${WSO2_PORT:-8280}
WSO2_MGMT_PORT=${WSO2_MGMT_PORT:-9443}
QUEUE_DEPTH_WARN=${QUEUE_DEPTH_WARN:-1000}
OK="[OK]"; WARN="[WARN]"; CRIT="[CRIT]"
SEP="─────────────────────────────────────────"
RESULT=0
echo "======================================================"
echo " GUARDiA SM 점검 | ESB/MQ (${ESB_TYPE}) | $(hostname -s)"
echo " 점검 시각: $(date '+%Y-%m-%d %H:%M:%S %Z')"
echo "======================================================"
# ════════════════════════════════════════════
# ActiveMQ
# ════════════════════════════════════════════
check_activemq() {
echo; echo "[$SEP] 1. ActiveMQ 프로세스"
AMQ_PROC=$(pgrep -c "activemq" 2>/dev/null || echo 0)
if [ "$AMQ_PROC" -gt 0 ]; then
echo " ${OK} ActiveMQ 실행 중 (${AMQ_PROC}개)"
else
echo " ${CRIT} ActiveMQ 프로세스 없음"
RESULT=2
fi
echo; echo "[$SEP] 2. 포트 리스닝"
for PORT in $ACTIVEMQ_PORT 61613 61614; do
ss -tlnp 2>/dev/null | grep -q ":${PORT} " && \
echo " ${OK} 포트 ${PORT} LISTEN" || \
echo " ${WARN} 포트 ${PORT} LISTEN 없음"
done
echo; echo "[$SEP] 3. 웹 콘솔 (Jolokia REST API)"
if command -v curl &>/dev/null; then
# 브로커 상태
BROKER=$(curl -sk --max-time 5 \
-u "${ACTIVEMQ_USER}:${ACTIVEMQ_PASS}" \
"${ACTIVEMQ_CONSOLE}/api/jolokia/read/org.apache.activemq:type=Broker,brokerName=localhost/TotalEnqueueCount,TotalDequeueCount,TotalConsumerCount,TotalProducerCount" \
2>/dev/null || echo "")
if echo "$BROKER" | python3 -c "import sys,json; d=json.load(sys.stdin); \
v=d.get('value',{}); \
[print(f' {k}: {val}') for k,val in v.items()]" 2>/dev/null; then
echo " ${OK} 브로커 상태 정상"
else
echo " ${WARN} Jolokia API 응답 없음 (웹 콘솔 접근 불가)"
[ $RESULT -lt 1 ] && RESULT=1
fi
# DLQ (Dead Letter Queue) 확인
DLQ=$(curl -sk --max-time 5 \
-u "${ACTIVEMQ_USER}:${ACTIVEMQ_PASS}" \
"${ACTIVEMQ_CONSOLE}/api/jolokia/search/org.apache.activemq:type=Broker,brokerName=localhost,destinationType=Queue,destinationName=ActiveMQ.DLQ" \
2>/dev/null || echo "")
if echo "$DLQ" | grep -q "DLQ"; then
DLQ_DEPTH=$(curl -sk --max-time 5 \
-u "${ACTIVEMQ_USER}:${ACTIVEMQ_PASS}" \
"${ACTIVEMQ_CONSOLE}/api/jolokia/read/org.apache.activemq:type=Broker,brokerName=localhost,destinationType=Queue,destinationName=ActiveMQ.DLQ/QueueSize" \
2>/dev/null | python3 -c "import sys,json; print(json.load(sys.stdin).get('value',0))" 2>/dev/null || echo 0)
if [ "${DLQ_DEPTH:-0}" -gt 0 ]; then
echo " ${WARN} DLQ 메시지 ${DLQ_DEPTH}"
[ $RESULT -lt 1 ] && RESULT=1
else
echo " ${OK} DLQ 비어있음"
fi
fi
fi
echo; echo "[$SEP] 4. 로그 오류"
for LOGDIR in "${ACTIVEMQ_HOME}/data" "${ACTIVEMQ_HOME}/logs"; do
LOGFILE=$(ls -t "${LOGDIR}"/activemq.log 2>/dev/null | head -1 || echo "")
if [ -n "$LOGFILE" ] && [ -r "$LOGFILE" ]; then
ERR=$(tail -500 "$LOGFILE" | grep -cE "ERROR|FATAL|Exception" || echo 0)
echo " 최근 오류: ${ERR}건 (${LOGFILE})"
[ "$ERR" -gt 0 ] && tail -500 "$LOGFILE" | grep -E "ERROR|FATAL" | tail -5 | sed 's/^/ /'
break
fi
done
}
# ════════════════════════════════════════════
# IBM MQ
# ════════════════════════════════════════════
check_ibmmq() {
export PATH="${IBMMQ_HOME}/bin:${PATH}"
echo; echo "[$SEP] 1. IBM MQ 프로세스"
MQ_PROC=$(pgrep -c "amq[a-z]" 2>/dev/null || echo 0)
if [ "$MQ_PROC" -gt 0 ]; then
echo " ${OK} IBM MQ 실행 중 (${MQ_PROC}개)"
else
echo " ${CRIT} IBM MQ 프로세스 없음"
RESULT=2
fi
echo; echo "[$SEP] 2. 큐 매니저 상태"
if command -v dspmq &>/dev/null; then
QMGR_STATUS=$(dspmq 2>/dev/null | grep "$MQ_QMGR" || echo "조회 실패")
echo " ${QMGR_STATUS}"
echo "$QMGR_STATUS" | grep -qi "running" && echo " ${OK} 큐 매니저 Running" || \
{ echo " ${CRIT} 큐 매니저 비정상"; RESULT=2; }
fi
echo; echo "[$SEP] 3. 큐 깊이"
if command -v runmqsc &>/dev/null; then
QUEUE_INFO=$(echo "DISPLAY QL(*) CURDEPTH" | runmqsc "$MQ_QMGR" 2>/dev/null | \
grep "CURDEPTH" | awk '{print $0}' | head -20 || echo "")
echo "$QUEUE_INFO" | sed 's/^/ /' | head -15
DEEP=$(echo "$QUEUE_INFO" | awk -F'CURDEPTH\\(' '{print $2}' | tr -d ')' | \
sort -rn | head -1 || echo 0)
if [ "${DEEP:-0}" -gt "$QUEUE_DEPTH_WARN" ]; then
echo " ${WARN} 최대 큐 깊이: ${DEEP}"
[ $RESULT -lt 1 ] && RESULT=1
else
echo " ${OK} 큐 깊이 정상 (최대: ${DEEP})"
fi
fi
echo; echo "[$SEP] 4. 채널 상태"
if command -v runmqsc &>/dev/null; then
CH_STATUS=$(echo "DISPLAY CHSTATUS(*)" | runmqsc "$MQ_QMGR" 2>/dev/null | \
grep "CHSTATUS" | head -10 || echo "채널 없음")
echo "$CH_STATUS" | sed 's/^/ /'
fi
}
# ════════════════════════════════════════════
# WSO2 ESB / Micro Integrator
# ════════════════════════════════════════════
check_wso2() {
echo; echo "[$SEP] 1. WSO2 프로세스"
WSO2_PROC=$(pgrep -f "wso2\|carbon" 2>/dev/null | wc -l || echo 0)
if [ "$WSO2_PROC" -gt 0 ]; then
echo " ${OK} WSO2 실행 중 (${WSO2_PROC}개)"
else
echo " ${CRIT} WSO2 프로세스 없음"
RESULT=2
fi
echo; echo "[$SEP] 2. 포트 리스닝"
for PORT in $WSO2_PORT $WSO2_MGMT_PORT; do
ss -tlnp 2>/dev/null | grep -q ":${PORT} " && \
echo " ${OK} 포트 ${PORT} LISTEN" || \
echo " ${WARN} 포트 ${PORT} LISTEN 없음"
done
echo; echo "[$SEP] 3. 관리 콘솔 응답"
if command -v curl &>/dev/null; then
HTTP_CODE=$(curl -sk -o /dev/null -w "%{http_code}" \
--max-time 10 "https://localhost:${WSO2_MGMT_PORT}/carbon/admin/login.jsp" \
2>/dev/null || echo "ERR")
if echo "$HTTP_CODE" | grep -qE "^[23]"; then
echo " ${OK} 관리 콘솔 응답: ${HTTP_CODE}"
else
echo " ${WARN} 관리 콘솔 응답: ${HTTP_CODE}"
[ $RESULT -lt 1 ] && RESULT=1
fi
fi
echo; echo "[$SEP] 4. WSO2 로그 오류"
for LOGDIR in "${WSO2_HOME}/repository/logs" "${WSO2_HOME}/logs"; do
if [ -d "$LOGDIR" ]; then
LOGFILE=$(ls -t "${LOGDIR}"/wso2*.log "${LOGDIR}"/carbon*.log 2>/dev/null | head -1 || echo "")
if [ -n "$LOGFILE" ] && [ -r "$LOGFILE" ]; then
ERR=$(tail -1000 "$LOGFILE" | grep -cE "ERROR|FATAL" || echo 0)
echo " 최근 오류: ${ERR}"
[ "$ERR" -gt 0 ] && tail -1000 "$LOGFILE" | grep -E "ERROR|FATAL" | tail -5 | sed 's/^/ /'
fi
break
fi
done
}
# 타입별 실행
case "${ESB_TYPE,,}" in
activemq) check_activemq ;;
ibmmq|mq) check_ibmmq ;;
wso2) check_wso2 ;;
*)
echo " ${WARN} 알 수 없는 ESB_TYPE: ${ESB_TYPE}"
echo " 지원: activemq, ibmmq, wso2"
[ $RESULT -lt 1 ] && RESULT=1
;;
esac
# ── 요약 ─────────────────────────────────────────────────
echo
echo "======================================================"
case $RESULT in
0) echo " 최종 결과: ${OK} ESB/MQ 정상" ;;
1) echo " 최종 결과: ${WARN} 주의 항목 있음" ;;
2) echo " 최종 결과: ${CRIT} 즉시 조치 필요" ;;
esac
echo " 점검 완료: $(date '+%Y-%m-%d %H:%M:%S')"
echo "======================================================"
exit $RESULT