Запустите jboss-cli только один раз - PullRequest
0 голосов
/ 18 июня 2020

Я хочу создать сценарий bash / shell, который отслеживает использование памяти JVM Wildfly с помощью jboss-cli. Поэтому мне нужно получить хосты и получить серверы Wildfly для каждого хоста в течение l oop. Однако запуск / подключение jboss-cli занимает несколько секунд и нагружает процессор. Это делает сценарий очень медленным. Отправка команд в интерактивном сеансе jboss-cli выполняется довольно быстро.

Есть ли способ подключиться к jboss-cli только один раз и отправить команды ввода в этот активный сеанс? Мне нужен вывод команд, чтобы продолжить выполнение сценария.

Текущий сценарий:

# List all hosts:
hosts="$(jboss-cli.sh -c --controller=servername:9990 --command=":read-children-names(child-type=host)" | grep "        " | awk '{print $1}' | sed 's/,//g' | sed 's/"//g')"
# Loop through hosts results:
for host in $hosts
{       
        #List all servers:
        servers="$(jboss-cli.sh -c --controller=servername:9990 --command="/host=$host:read-children-names(child-type=server)" | grep "        " | awk '{print $1}' | sed 's/,//g' | sed 's/"//g')"
        # Loop through server results:
        for server in $servers
        {
            # check if server is running:
            serverstate=$(jboss-cli.sh -c --controller=servername:9990 --command="/host=$host/server=$server:read-attribute(name=server-state)" | grep "result" | awk '{print $3}' | sed 's/"//g')

            if [ $serverstate = "running" ]
            then
                #Do a check etc. etc.
            fi
        }       
}

1 Ответ

0 голосов
/ 18 июня 2020

Была похожая проблема. Мое решение использует сопрограмму в k sh, и я не знаю, возможно ли это в bash, например, ваш флаг (но если установлен k sh, вы все равно можете его использовать). По крайней мере, это может дать вам несколько указателей.

#!/bin/ksh

#connecting using coroutine -- Note the |& at the end
{JBOSS_HOME}/bin/jboss-cli.sh --connect --controller={Master_IP}:{Master_Port} --user={UID} --password={Password} |&
#sending request to coroutine
print -p "ls -l /host\n"
#Reading from corouting
while read -p answer; do
##Need to verify when stop reading -- after the prompt is back
    if [[ $answer != *domain*:* ]]; then
    ## If it's not an error, concatenate, space delimited, the response
        if [[ $answer == *WFLYCTL* ]]; then
            print "$(date +"%Y%m%d%H%M") - FATAL - Error detected - Exiting"
            print "$(date +"%Y%m%d%H%M") - Error detected : $answer"
            exit
        else
            Dummy+=$answer" "
        fi
    elif [[ locFlag -eq 1 ]]; then
        locFlag=0
        break
    else
        locFlag=1
    fi
done
##Response to array
SvrArray=( $Dummy )
##Do anything with the response, here just printing
for i in ${!SvrArray[@]}; do
        print "$i. ${SvrArray[$i]}"
done
...