mirror of
https://github.com/iiab/iiab.git
synced 2025-03-09 15:40:17 +00:00
more useful /usr/bin/diagnostics command
This commit is contained in:
parent
a049acf97a
commit
81f5e819cc
1 changed files with 120 additions and 145 deletions
|
@ -1,200 +1,175 @@
|
|||
#!/bin/bash
|
||||
|
||||
# Collect IIAB diagnostic info for easy online/offline circulation
|
||||
# Collect IIAB diagnostic info into 1 file for easy online/offline circulation!
|
||||
# PLEASE SEE iiab-diagnostics.README.md
|
||||
|
||||
# Build up a meaningful filename for dev/impl/educ team(s)
|
||||
IIAB_RELEASE=`cat /etc/iiab/iiab.env | grep IIAB_RELEASE | cut -d'=' -f2`
|
||||
OS_VER=`cat /etc/iiab/iiab.env | grep OS_VER | cut -d'=' -f2`
|
||||
#HASH=`cd /opt/iiab/iiab; git log --pretty=format:'%h' -n 1`
|
||||
HASH1=`cd /opt/iiab/iiab; git log --pretty=format:'%H' -n 1`
|
||||
HASH2=`cd /opt/iiab/iiab-admin-console; git log --pretty=format:'%H' -n 1`
|
||||
YMDT=$(date +%F_%T_%Z)
|
||||
|
||||
read -p "\n\nOptionally, please provide a nickname: " nickname
|
||||
echo -e "\nAccelerate troubleshooting by collecting your IIAB diagnostics into 1 file:"
|
||||
echo -e "\n sudo iiab-diagnostics"
|
||||
echo -e " sudo iiab-diagnostics FILE1 FILE2"
|
||||
echo -ne "\nCan you provide a \e[1mshort public nickname:\e[0m (no spaces!) "
|
||||
read nickname < /dev/tty
|
||||
if [ -z "$nickname" ]; then
|
||||
nickname="NONAME"
|
||||
fi
|
||||
|
||||
outfile=/etc/iiab/diagnostics/${OS_VER}-$YMDT-$nickname
|
||||
echo "Compiling diagnostics to... $outfile"
|
||||
# Build up a meaningful shared filename for DEV / IMPLEM / LEARNING team(s)
|
||||
outfile=/etc/iiab/diag/${IIAB_RELEASE}_${OS_VER}_${YMDT}_$nickname
|
||||
mkdir -p /etc/iiab/diag
|
||||
|
||||
#SCRIPTDIR=$(cd `dirname $0` pwd)
|
||||
#diagnostics_name=${OS_VER}_$YMDT_$nickname
|
||||
#outfile=/tmp/$diagnostics_name.$$
|
||||
#filelist=/opt/iiab/iiab/scripts/iiab-diagnostics.filelist
|
||||
#VARS_VALUES=/tmp/all-vars
|
||||
|
||||
# Record all Ansible variables
|
||||
#pushd /opt/iiab/iiab > /dev/null
|
||||
#./runrole all-vars $VARS_VALUES
|
||||
#popd > /dev/null
|
||||
|
||||
function cat_file() {
|
||||
echo "=IIAB====================================================" >> $outfile
|
||||
function cat_file_raw() { # $1 = path/filename; $2 = # of lines, for tail
|
||||
if [ -f $1 ]; then
|
||||
if [ $# -eq 1 ]; then
|
||||
echo "FILE $1" >> $outfile
|
||||
ls -l $1 >> $outfile
|
||||
if [ ! -s $1 ]; then
|
||||
echo >> $outfile
|
||||
echo "FILE EXISTS BUT IS EMPTY!" >> $outfile
|
||||
elif [ $# -eq 1 ]; then
|
||||
echo >> $outfile
|
||||
cat $1 | iconv -t UTF-8//IGNORE >> $outfile
|
||||
else
|
||||
echo "LAST 100 LINES OF FILE $1" >> $outfile
|
||||
else # e.g. last 100 lines, maximum
|
||||
echo " ...ITS LAST $2 LINES FOLLOW..." >> $outfile
|
||||
echo >> $outfile
|
||||
tail -100 $1 | iconv -t UTF-8//IGNORE >> $outfile
|
||||
tail -$2 $1 | iconv -t UTF-8//IGNORE >> $outfile
|
||||
fi
|
||||
echo >> $outfile
|
||||
else
|
||||
echo "FILE $1 DOES NOT EXIST" >> $outfile
|
||||
if [ -d $1 ]; then
|
||||
ls -ld $1 >> $outfile
|
||||
echo >> $outfile
|
||||
echo "THIS IS A DIRECTORY NOT A FILE!" >> $outfile
|
||||
echo >> $outfile
|
||||
else
|
||||
echo "FILE DOES NOT EXIST: $1" >> $outfile
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
#function cat_file_list() {
|
||||
# for f in $(cat $filelist); do
|
||||
# cat_file $f
|
||||
# done
|
||||
#}
|
||||
function cat_file() {
|
||||
echo " $1"
|
||||
echo "=IIAB==========================================================================" >> $outfile
|
||||
cat_file_raw $1
|
||||
}
|
||||
|
||||
# cat files in this direcory
|
||||
function cat_dir() {
|
||||
echo "=IIAB=====================================================" >> $outfile
|
||||
echo " $1"
|
||||
echo "=IIAB==========================================================================" >> $outfile
|
||||
if [ -d "$1" ]; then
|
||||
echo "FILES IN DIRECTORY $1 TO FOLLOW..." >> $outfile
|
||||
filelist=$(ls $1)
|
||||
if [ ! -z "$filelist" ]; then
|
||||
pushd $1
|
||||
for f in `ls *`; do
|
||||
echo "-IIAB-----------------------------------------------------" >> $outfile
|
||||
echo "FILE $1/$f" >> $outfile
|
||||
echo >> $outfile
|
||||
cat $f | iconv -t UTF-8//IGNORE >> $outfile
|
||||
echo >> $outfile
|
||||
echo "DIRECTORY $1 FILES WILL FOLLOW...IF THEY EXIST" >> $outfile
|
||||
for f in $(ls $1); do
|
||||
echo "-IIAB--------------------------------------------------------------------------" >> $outfile
|
||||
cat_file_raw $1/$f 100
|
||||
done
|
||||
popd
|
||||
fi
|
||||
else
|
||||
echo "DIRECTORY $1 DOES NOT EXIST" >> $outfile
|
||||
echo "DIRECTORY DOES NOT EXIST: $1" >> $outfile
|
||||
fi
|
||||
}
|
||||
|
||||
# cat output of command
|
||||
function cat_cmd() {
|
||||
echo "=IIAB=====================================================" >> $outfile
|
||||
path=$(which $bla1 | sed 's/[^/]*$//')
|
||||
echo "$path$1 # $2" >> $outfile
|
||||
function cat_cmd() { # $1 = command + params, $2 = explanation
|
||||
echo " $1 # $2"
|
||||
echo "=IIAB==========================================================================" >> $outfile
|
||||
cmd=$(echo $1 | sed 's/\s.*$//') # Keep command on left; Drop params on right
|
||||
pth=$(which $cmd | sed 's/[^/]*$//') # Keep only path on left; Drop command on right
|
||||
echo "COMMAND: $pth$1 # $2" >> $outfile
|
||||
echo >> $outfile
|
||||
$(echo $1) >> $outfile
|
||||
echo >> $outfile
|
||||
}
|
||||
|
||||
# Assemble script to later generate output from ~9 commands
|
||||
#cat << EOF > /tmp/iiab-diagnostics.script
|
||||
##!/bin/bash
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/sbin/ip addr # Network interfaces\n"
|
||||
#ip addr
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/sbin/ifconfig # Network interfaces (old view)\n"
|
||||
#ifconfig
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/sbin/brctl show # Bridge for LAN side\n"
|
||||
#brctl show
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/bin/netstat -rn # Routing table\n"
|
||||
#netstat -rn
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/bin/netstat -natp # Ports/Services in use\n"
|
||||
#netstat -natp
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/sbin/iptables-save # Firewall rules\n"
|
||||
#iptables-save
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/bin/systemctl status dnsmasq # Is dnsmasq Ok?\n"
|
||||
#systemctl status dnsmasq
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/bin/journalctl -u dnsmasq # dnsmasq log\n"
|
||||
#journalctl -u dnsmasq
|
||||
#echo "=IIAB====================================================="
|
||||
#echo -e "/usr/bin/ansible localhost -m setup 2>/dev/null # All Ansible facts\n"
|
||||
#ansible localhost -m setup 2>/dev/null
|
||||
#EOF
|
||||
#
|
||||
#chmod 755 /tmp/iiab-diagnostics.script
|
||||
function cat_tail() { # $1 = path/filename; $2 = # of lines, for tail
|
||||
echo " $1"
|
||||
echo "=IIAB==========================================================================" >> $outfile
|
||||
cat_file_raw $1 $2 # e.g. last 100 lines, maximum
|
||||
}
|
||||
|
||||
# Start building up the file that will contain the diagnostics
|
||||
mkdir -p /etc/iiab/diagnostics
|
||||
mv $outfile $outfile.old # Not really nec, given unique time stamps
|
||||
# START BUILDING UP THE FILE THAT'LL CONTAIN THE DIAGNOSTICS!
|
||||
echo -e "\nCompiling diagnostics..."
|
||||
|
||||
# HARVEST 0: Header & OS
|
||||
echo "=IIAB=====================================================" >> $outfile
|
||||
echo "This file is: $outfile" >> $outfile
|
||||
echo -e "\n 0. Header/Hashes/OS"
|
||||
echo "This is: $outfile" >> $outfile
|
||||
echo >> $outfile
|
||||
echo "iiab commit: $HASH1" >> $outfile
|
||||
echo "iiab-admin-console commit: $HASH2" >> $outfile
|
||||
echo "=IIAB=====================================================" >> $outfile
|
||||
echo "Checking /etc/rpi-issue for Raspbian OS version..." >> $outfile
|
||||
echo >> $outfile
|
||||
echo -n "Checking /etc/rpi-issue for Raspbian OS version... " >> $outfile
|
||||
if [ -f /etc/rpi-issue ]; then
|
||||
echo >> $outfile
|
||||
cat /etc/rpi-issue >> $outfile
|
||||
echo >> $outfile
|
||||
echo "stage2 = lite; stage5 = desktop SEE https://github.com/RPi-Distro/pi-gen#stage-anatomy" >> $outfile
|
||||
else
|
||||
echo "Not a Raspberry Pi." >> $outfile
|
||||
echo "Not a Raspberry Pi!" >> $outfile
|
||||
fi
|
||||
echo >> $outfile
|
||||
|
||||
# HARVEST 1: Files
|
||||
#cat_file_list
|
||||
echo -e "\n 1. Files specially requested: (e.g. iiab-diagnostics FILE1 FILE2)\n"
|
||||
for f in "$@"; do
|
||||
cat_file $f
|
||||
done
|
||||
|
||||
if [ $# -eq 0 ]; then
|
||||
echo -e " 2. Regular Files:\n"
|
||||
else
|
||||
echo -e "\n 2. Regular Files:\n"
|
||||
fi
|
||||
#cat_file /dev/sda # Device "file" test
|
||||
#cat_file /nonsense # Non-existence test
|
||||
#cat_file /opt/iiab/iiab # Directory test
|
||||
#cat_file /tmp/empty-file # Empty file test
|
||||
#cat_file /usr/bin/iiab-support-on # Symlink test
|
||||
cat_file /etc/iiab/openvpn_handle
|
||||
cat_file /.iiab-image
|
||||
cat_file /etc/iiab/iiab.env
|
||||
cat_file /etc/iiab/iiab.ini
|
||||
cat_file /etc/iiab/local_vars.yml
|
||||
cat_file /etc/iiab/config_vars.yml
|
||||
cat_file /etc/iiab/openvpn_handle
|
||||
cat_file /etc/resolv.conf
|
||||
cat_file /etc/network/interfaces
|
||||
cat_file /usr/bin/iiab-gen-iptables
|
||||
cat_file /.iiab-image
|
||||
|
||||
#echo "=IIAB====================================================="
|
||||
#if [ -f /.iiab-image ]; then
|
||||
# echo "Output of /bin/cat /.iiab-image command."
|
||||
# echo
|
||||
# cat /.iiab-image
|
||||
#else
|
||||
# echo /.iiab-image does not exist.
|
||||
#fi
|
||||
#echo
|
||||
# Record all Ansible variables: SLOW! OUTPUT TOO LARGE?
|
||||
#pushd /opt/iiab/iiab > /dev/null
|
||||
#./runrole all-vars /tmp/all-ansible-vars
|
||||
#popd > /dev/null
|
||||
#cat_file /tmp/all-ansible-var
|
||||
|
||||
# HARVEST 2: Contents of Directories
|
||||
echo -e "\n 3. Content of Directories, 1-level deep:\n"
|
||||
cat_dir /etc/network/interfaces.d
|
||||
cat_dir /etc/systemd/network
|
||||
cat_dir /etc/NetworkManager/system-connections
|
||||
cat_dir /etc/sysconfig/network-scripts/if-cfg*
|
||||
cat_dir /etc/sysconfig/network-scripts/if-cfg* # TEST ON RPi ETC!
|
||||
cat_dir /etc/netplan
|
||||
#cat_dir /etc/network # Above file /etc/network/interfaces suffices
|
||||
|
||||
# HARVEST 3: Output of Commands
|
||||
#/tmp/iiab-diagnostics.script >> $outfile
|
||||
cat_cmd "ip addr" "Network interfaces"
|
||||
cat_cmd "ifconfig" "Network interfaces (old view)"
|
||||
cat_cmd "brctl show" "Bridge for LAN side"
|
||||
cat_cmd "netstat -rn" "Routing table"
|
||||
cat_cmd "netstat -natp" "Ports/Services in use"
|
||||
cat_cmd "iptables-save" "Firewall rules"
|
||||
cat_cmd "systemctl status dnsmasq" "Is dnsmasq Ok?"
|
||||
cat_cmd "journalctl -u dnsmasq" "dnsmasq log"
|
||||
cat_cmd "ansible localhost -m setup 2>/dev/null" "All Ansible facts"
|
||||
echo -e "\n 4. Output of Commands:\n"
|
||||
cat_cmd 'uname -a' 'Linux kernel'
|
||||
cat_cmd 'free' 'RAM memory'
|
||||
cat_cmd 'lscpu' 'CPU details'
|
||||
cat_cmd 'df -h' 'Disk usage'
|
||||
cat_cmd 'lsblk' 'Partition mount points'
|
||||
cat_cmd 'blkid' 'Mount point details'
|
||||
cat_cmd 'ip addr' 'Network interfaces'
|
||||
cat_cmd 'ifconfig' 'Network interfaces (old view)'
|
||||
cat_cmd 'brctl show' 'Bridge for LAN side'
|
||||
cat_cmd 'netstat -rn' 'Routing table'
|
||||
cat_cmd 'netstat -natp' 'Ports/Services in use'
|
||||
cat_cmd 'iptables-save' 'Firewall rules'
|
||||
cat_cmd 'systemctl status dnsmasq' 'Is dnsmasq Ok?'
|
||||
cat_cmd 'journalctl -u dnsmasq' 'dnsmasq log'
|
||||
#cat_cmd 'ansible localhost -m setup 2>/dev/null' 'All Ansible facts'
|
||||
|
||||
#if [ -f "$VARS_VALUES" ]; then
|
||||
# cat "$VARS_VALUES" >> $outfile
|
||||
#fi
|
||||
echo -e "\n 5. Log Files: (last 100 lines of each)\n"
|
||||
cat_tail /opt/iiab/iiab/iiab-install.log 100
|
||||
cat_tail /opt/iiab/iiab/iiab-network.log 100
|
||||
cat_tail /opt/iiab/iiab/iiab-debug.log 100
|
||||
cat_tail /opt/iiab/iiab-admin-console/admin-install.log 100
|
||||
|
||||
# HARVEST 4: Log Files -- last 100 lines
|
||||
cat_file /opt/iiab/iiab/iiab-install.log last
|
||||
cat_file /opt/iiab/iiab/iiab-network.log last
|
||||
cat_file /opt/iiab/iiab/iiab-debug.log last
|
||||
cat_file /opt/iiab/iiab-admin-console/admin-install.log last
|
||||
|
||||
#mkdir -p /etc/iiab/diagnostics
|
||||
#if [ ! -z $outfile ]; then
|
||||
# pushd /tmp > /dev/null
|
||||
# cp $outfile /etc/iiab/diagnostics/
|
||||
# popd > /dev/null
|
||||
# #rm -rf $outfile
|
||||
# #exit 0
|
||||
#fi
|
||||
|
||||
echo -e "Complete! You can now run:\n\npastebinit < $outfile\n"
|
||||
linecount=$(wc -l $outfile | sed 's/\s.*$//')
|
||||
sizecount=$(du -h $outfile | sed 's/\s.*$//')
|
||||
echo -e "\n\e[32mCOMPLETE! To share this on the web ($sizecount, $linecount lines) run:\e[0m"
|
||||
echo -e "\n\e[1mpastebinit < $outfile\e[0m\n"
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue