feat(node_dump): Create a node dump script

This commit is contained in:
k32 2021-05-04 19:38:41 +02:00 committed by Zaiming (Stone) Shi
parent 9dc1e162fa
commit d913a7d20d
2 changed files with 45 additions and 0 deletions

44
bin/node_dump Executable file
View File

@ -0,0 +1,44 @@
#!/bin/bash
set -euo pipefail
shopt -s nullglob
ROOT_DIR="$(cd "$(dirname "$(readlink "$0" || echo "$0")")"/..; pwd -P)"
echo "Running node dump in ${ROOT_DIR}"
cd "${ROOT_DIR}"
DUMP="log/node_dump_$(date +"%y%m%d_%H%M%S").tar.gz"
collect() {
echo "========================================================"
echo " $@"
echo "========================================================"
eval $@ || echo "Unavailable"
echo -e '\n'
}
{
collect bin/emqx_ctl broker
collect uname -a
collect uptime
collect free -h
collect netstat -tnl
collect bin/emqx_ctl plugins list
collect bin/emqx_ctl modules list
collect bin/emqx_ctl vm all
collect bin/emqx_ctl listeners
} > log/sysinfo.txt
bin/emqx eval 'ets:tab2list(ac_tab)' > log/conf.dump
tar czf $DUMP log/*.log.* log/run_erl.log* log/sysinfo.txt log/conf.dump
## Cleanup:
rm log/sysinfo.txt
rm log/conf.dump
echo "Created a node dump ${DUMP}"

View File

@ -317,6 +317,7 @@ relx_overlay(ReleaseType) ->
, {template, "data/emqx_vars", "releases/emqx_vars"}
, {copy, "bin/emqx", "bin/emqx"}
, {copy, "bin/emqx_ctl", "bin/emqx_ctl"}
, {copy, "bin/node_dump", "bin/node_dump"}
, {copy, "bin/install_upgrade.escript", "bin/install_upgrade.escript"}
, {copy, "bin/emqx", "bin/emqx-{{release_version}}"} %% for relup
, {copy, "bin/emqx_ctl", "bin/emqx_ctl-{{release_version}}"} %% for relup