297 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			297 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|  | #!/bin/bash | ||
|  | # Copyright (C) 2019 tribe29 GmbH - License: GNU General Public License v2 | ||
|  | # This file is part of Checkmk (https://checkmk.com). It is subject to the terms and | ||
|  | # conditions defined in the file COPYING, which is part of this source code package. | ||
|  | 
 | ||
|  | # Reason for this no-op: shellcheck disable=... before the first command disables the error for the | ||
|  | # entire script. | ||
|  | : | ||
|  | 
 | ||
|  | # Disable unused variable error (needed to keep track of version) | ||
|  | # shellcheck disable=SC2034 | ||
|  | CMK_VERSION="2.0.0p17" | ||
|  | 
 | ||
|  | # Informix | ||
|  | # Make ENV-VARs avail for subshells | ||
|  | set -a | ||
|  | 
 | ||
|  | #   .--helper--------------------------------------------------------------. | ||
|  | #   |                    _          _                                      | | ||
|  | #   |                   | |__   ___| |_ __   ___ _ __                      | | ||
|  | #   |                   | '_ \ / _ \ | '_ \ / _ \ '__|                     | | ||
|  | #   |                   | | | |  __/ | |_) |  __/ |                        | | ||
|  | #   |                   |_| |_|\___|_| .__/ \___|_|                        | | ||
|  | #   |                                |_|                                   | | ||
|  | #   '----------------------------------------------------------------------' | ||
|  | 
 | ||
|  | 
 | ||
|  | function do_check () { | ||
|  |     # $1:section, $2:excludelist | ||
|  |     if echo "$2" | grep -qe "${1}"; then | ||
|  |         return 1 | ||
|  |     else | ||
|  |         return 0 | ||
|  |     fi | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function sql () { | ||
|  |     db="sysmaster" | ||
|  |     sqltxt="$1" | ||
|  |     export DBDELIMITER="|" | ||
|  |     echo "$sqltxt" | dbaccess ${db} | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function set_excludes () { | ||
|  |     excludes="" | ||
|  |     if [ "$EXCLUDES" = "ALL" ]; then | ||
|  |         excludes="$all_sections" | ||
|  |         global_exclude=true | ||
|  |     elif [ ! -z "$EXCLUDES" ]; then | ||
|  |         excludes=$EXCLUDES | ||
|  |         global_exclude=true | ||
|  |     else | ||
|  |         global_exclude=false | ||
|  |     fi | ||
|  | 
 | ||
|  |     if [ "$global_exclude" = "false" ]; then | ||
|  |         excludes_i="EXCLUDES_${1}" | ||
|  |         if [ "${!excludes_i}" = "ALL" ]; then | ||
|  |             excludes="$all_sections" | ||
|  |         elif [ ! -z "${!excludes_i}" ]; then | ||
|  |             excludes=${!excludes_i} | ||
|  |         fi | ||
|  |     fi | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | #. | ||
|  | #   .--sqls----------------------------------------------------------------. | ||
|  | #   |                                     _                                | | ||
|  | #   |                           ___  __ _| |___                            | | ||
|  | #   |                          / __|/ _` | / __|                           | | ||
|  | #   |                          \__ \ (_| | \__ \                           | | ||
|  | #   |                          |___/\__, |_|___/                           | | ||
|  | #   |                                  |_|                                 | | ||
|  | #   '----------------------------------------------------------------------' | ||
|  | 
 | ||
|  | 
 | ||
|  | all_sections="sessions locks tabextents dbspaces logusage" | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_status(){ | ||
|  |     echo "<<<informix_status:sep(58)>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     $INFORMIXDIR/bin/onstat - >/dev/null 2>&1 | ||
|  |     state=$? | ||
|  |     echo "Status:"$state | ||
|  |     $INFORMIXDIR/bin/onstat -g dis | ||
|  |     port=$(grep $INFORMIXSERVER /etc/services) | ||
|  |     echo "PORT:"$port | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_sessions(){ | ||
|  |     echo "<<<informix_sessions>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     # don't count our own session | ||
|  |     sql "select 'SESSIONS', (count(*)-1)::int from syssessions" | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_locks(){ | ||
|  |     echo "<<<informix_locks>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     # don't count our own session | ||
|  |     sql "select 'LOCKS', (count(*)-1)::int, type from syslocks group by type" | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_tabextents(){ | ||
|  |     echo "<<<informix_tabextents>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     sql "select first 10 | ||
|  |             'TABEXTENTS', | ||
|  |             trim(n.dbsname) db, | ||
|  |             trim(n.tabname) tab, | ||
|  |             h.nextns extents, | ||
|  |             nrows | ||
|  |         from sysptnhdr h, systabnames n | ||
|  |         where h.partnum = n.partnum | ||
|  |         and nrows > 0 | ||
|  |         and n.dbsname not in ( 'sysadmin', 'sysuser', 'sysutils', 'sysmaster' ) | ||
|  |         and n.tabname not like 'sys%' | ||
|  |         order by extents desc" | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_dbspaces(){ | ||
|  |     echo "<<<informix_dbspaces>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     sql "select | ||
|  |             trim(sd.name) || ' DBSPACE', | ||
|  |             sd.dbsnum, | ||
|  |             sd.is_temp, | ||
|  |             sd.flags, | ||
|  |             'CHUNK', | ||
|  |             sc.fname, | ||
|  |             sc.pagesize, | ||
|  |             sc.chksize, | ||
|  |             sc.nfree, | ||
|  |             sc.flags, | ||
|  |             trim(sc.mfname), | ||
|  |             sc.mflags | ||
|  |         from sysdbspaces sd, syschunks sc | ||
|  |         where sd.dbsnum = sc.dbsnum | ||
|  |         -- NO SBSPACE CURRENTLY | ||
|  |         and sd.is_sbspace = 0 | ||
|  |         order by sd.name" | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_logusage(){ | ||
|  |     echo "<<<informix_logusage>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     sql "select 'LOGUSAGE', | ||
|  |             number, | ||
|  |             sh_pagesize, | ||
|  |             size, | ||
|  |             used, | ||
|  |             flags, | ||
|  |             'is_used:'||is_used, | ||
|  |             'is_current:'||is_current, | ||
|  |             'is_backed_up:'||is_backed_up, | ||
|  |             'is_new:'||is_new, | ||
|  |             'is_archived:'||is_archived, | ||
|  |             'is_temp:'||is_temp, | ||
|  |             'is_pre_dropped:'||is_pre_dropped | ||
|  |         from syslogs, sysshmvals | ||
|  |         order by number" | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | function informix_transactions(){ | ||
|  |     echo "<<<informix_transactions>>>" | ||
|  |     echo "[[[$INFORMIXSERVER/$SERVERNUM]]]" | ||
|  |     $INFORMIXDIR/bin/onstat -l | grep C | tail -n 1 | ||
|  |     $INFORMIXDIR/bin/onstat -x |egrep -v "IBM|maximum|Transactions|est.|userthread" | sed 's/:[^:]*$//' | ||
|  | } | ||
|  | #. | ||
|  | #   .--config--------------------------------------------------------------. | ||
|  | #   |                                      __ _                            | | ||
|  | #   |                      ___ ___  _ __  / _(_) __ _                      | | ||
|  | #   |                     / __/ _ \| '_ \| |_| |/ _` |                     | | ||
|  | #   |                    | (_| (_) | | | |  _| | (_| |                     | | ||
|  | #   |                     \___\___/|_| |_|_| |_|\__, |                     | | ||
|  | #   |                                           |___/                      | | ||
|  | #   '----------------------------------------------------------------------' | ||
|  | 
 | ||
|  | 
 | ||
|  | # Config opts: | ||
|  | # - oninit-path; Default is empty, which means autodetection: | ||
|  | #       ONINIT_PATH=<path to oninit-binary> | ||
|  | # - Excluding sections ("status sessions locks tabextents dbspaces logusage"): | ||
|  | #       EXCLUDES_INFORMIX_INSTANCE="SECTION SECTION ..." | ||
|  | #       EXCLUDES_INFORMIX_INSTANCE=ALL | ||
|  | #       EXCLUDES="SECTION SECTION ..." | ||
|  | #       EXCLUDES=ALL | ||
|  | 
 | ||
|  | 
 | ||
|  | if [ -f "$MK_CONFDIR/informix.cfg" ]; then | ||
|  |     . $MK_CONFDIR/informix.cfg | ||
|  | fi | ||
|  | 
 | ||
|  | 
 | ||
|  | if [ -z "$ONINIT_PATH" -o ! -x "$ONINIT_PATH" ]; then | ||
|  |     ONINIT=$(UNIX95=true ps ax  | grep oninit | grep -v grep | head -1 | awk '{print $1 " " $5}') | ||
|  |     if [ -z "$ONINIT" ]; then | ||
|  |         exit 0 | ||
|  |     fi | ||
|  | 
 | ||
|  |     ONINIT_PATH=${ONINIT#* } | ||
|  |     ONINIT_PID=${ONINIT% *} | ||
|  |     case "$ONINIT_PATH" in | ||
|  |     /*) | ||
|  |         ;; | ||
|  |     *)    # BUG not platform independent! | ||
|  |         ONINIT_PATH=$(ls -l /proc/$ONINIT_PID/exe 2>/dev/null| sed 's/.* //') | ||
|  |         ;; | ||
|  |     esac | ||
|  | 
 | ||
|  |     # If not set in config or not found we end up here | ||
|  |     if [ -z "$ONINIT_PATH" -o ! -f "$ONINIT_PATH" ]; then | ||
|  |         exit 1 | ||
|  |     fi | ||
|  | fi | ||
|  | 
 | ||
|  | 
 | ||
|  | #. | ||
|  | #   .--main----------------------------------------------------------------. | ||
|  | #   |                                       _                              | | ||
|  | #   |                       _ __ ___   __ _(_)_ __                         | | ||
|  | #   |                      | '_ ` _ \ / _` | | '_ \                        | | ||
|  | #   |                      | | | | | | (_| | | | | |                       | | ||
|  | #   |                      |_| |_| |_|\__,_|_|_| |_|                       | | ||
|  | #   |                                                                      | | ||
|  | #   '----------------------------------------------------------------------' | ||
|  | 
 | ||
|  | 
 | ||
|  | for IDSENV in $( export INFORMIXDIR=${ONINIT_PATH%/bin*} | ||
|  |     $INFORMIXDIR/bin/onstat -g dis | \ | ||
|  |         egrep '^Server[         ]*:|^Server Number[     ]*:|^INFORMIX|^SQLHOSTS|^ONCONFIG' | \ | ||
|  |         sed -e 's/Server Number/SERVERNUM/' \ | ||
|  |             -e 's/Server/INFORMIXSERVER/' \ | ||
|  |             -e 's/SQLHOSTS/INFORMIXSQLHOSTS/' \ | ||
|  |             -e 's/[     ]*:[    ]*/=/' | \ | ||
|  |          tr '\n' ';' | \ | ||
|  |         sed -e 's/;$/\\n/'  -e 's/;\(INFORMIXSERVER=[^;]*;\)/\\n\1/g' | \ | ||
|  |          awk '{ gsub(/\\n/,"\n")}1' | ||
|  |     ) ; do | ||
|  |     ( | ||
|  |         # Set environment | ||
|  |         eval $IDSENV | ||
|  |         PATH=$INFORMIXDIR/bin:$PATH | ||
|  | 
 | ||
|  |             # try to set them via 'onstat -g env' otherwise | ||
|  |             # DB HAS TO BE RUNNING | ||
|  |             if [ -z "$INFORMIXSQLHOSTS" -o -z "$ONCONFIG" ]; then | ||
|  |                 onstat -g env | egrep -e '^INFORMIXSQLHOSTS' \ | ||
|  |                                       -e '^ONCONFIG' |       \ | ||
|  |                                 sed   -e 's/[         ][      ]*/=/' | ||
|  |             fi | ||
|  | 
 | ||
|  |         informix_status | ||
|  | 
 | ||
|  |         set_excludes $INFORMIXSERVER | ||
|  | 
 | ||
|  |         if do_check "sessions" "$excludes"; then | ||
|  |             informix_sessions | ||
|  |         fi | ||
|  | 
 | ||
|  |         if do_check "locks" "$excludes"; then | ||
|  |             informix_locks | ||
|  |         fi | ||
|  | 
 | ||
|  |         if do_check "tabextents" "$excludes"; then | ||
|  |             informix_tabextents | ||
|  |         fi | ||
|  | 
 | ||
|  |         if do_check "dbspaces" "$excludes"; then | ||
|  |             informix_dbspaces | ||
|  |         fi | ||
|  | 
 | ||
|  |         if do_check "logusage" "$excludes"; then | ||
|  |             informix_logusage | ||
|  |         fi | ||
|  | 
 | ||
|  |         if do_check "transactions" "$excludes"; then | ||
|  |             informix_transactions | ||
|  |         fi | ||
|  | 
 | ||
|  |     ) | ||
|  | done | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 |