sort by seconds

master
Marc Wäckerlin 7 years ago
parent 6486d66a9d
commit b219e169e7
  1. 40
      docker-status

@ -1,26 +1,22 @@
#!/bin/bash -e #!/bin/bash -e
############################################################################ begin logging ############################################################################ begin logging
# check if stdout is a terminal... # see if it supports colors...
if test -t 1; then ncolors=$(tput colors)
# see if it supports colors... if test -n "$ncolors" && test $ncolors -ge 8; then
ncolors=$(tput colors) bold="$(tput bold)"
underline="$(tput smul)"
if test -n "$ncolors" && test $ncolors -ge 8; then standout="$(tput smso)"
bold="$(tput bold)" normal="$(tput sgr0)"
underline="$(tput smul)" black="$(tput setaf 0)"
standout="$(tput smso)" red="$(tput setaf 1)"
normal="$(tput sgr0)" green="$(tput setaf 2)"
black="$(tput setaf 0)" yellow="$(tput setaf 3)"
red="$(tput setaf 1)" blue="$(tput setaf 4)"
green="$(tput setaf 2)" magenta="$(tput setaf 5)"
yellow="$(tput setaf 3)" cyan="$(tput setaf 6)"
blue="$(tput setaf 4)" white="$(tput setaf 7)"
magenta="$(tput setaf 5)"
cyan="$(tput setaf 6)"
white="$(tput setaf 7)"
fi
fi fi
append_msg() { append_msg() {
@ -171,7 +167,7 @@ services=$(for stack in ${stacks}; do
" "
for service in ${status}; do for service in ${status}; do
time=${service%%;*} time=${service%%;*}
echo "$(date -d "$(sed 's,about an* ,1 ,' <<<${time})");${service#*;}" echo "$(date +%s -d "$(sed 's,about an* ,1 ,' <<<${time})");${service#*;}"
done done
done | sort -hr) done | sort -hr)
@ -184,6 +180,6 @@ for service in ${services}; do
$5 !~ /^Running/ {printf "'"${red}"'%-15s%-40s%s %s%s\n", $3, $2, $5, $7, "'"${normal}"'"} $5 !~ /^Running/ {printf "'"${red}"'%-15s%-40s%s %s%s\n", $3, $2, $5, $7, "'"${normal}"'"}
$5 ~ /^Running/ && doshort==0 {printf "%s%-15s%-40s%s%s\n", color, $3, $2, $5, "'"${normal}"'"} $5 ~ /^Running/ && doshort==0 {printf "%s%-15s%-40s%s%s\n", color, $3, $2, $5, "'"${normal}"'"}
dolog==1 && (doshort==0 || $5 !~ /^Running/) {printf "ssh %s docker logs -f %s.%s\n", $3, $2, $6} dolog==1 && (doshort==0 || $5 !~ /^Running/) {printf "ssh %s docker logs -f %s.%s\n", $3, $2, $6}
doexec==1 && (dohort==0 || $5 !~ /^Running/) {printf "ssh %s docker exec -it %s.%s bash\n", $3, $2, $6} doexec==1 && (dohort==0 || $5 !~ /^Running/) {printf "ssh -t %s docker exec -it %s.%s bash\n", $3, $2, $6}
' <<<${service} ' <<<${service}
done done

Loading…
Cancel
Save