Autosys - получить список заданий на конкретном компьютере

Я пытаюсь получить список всех работ, выполняемых на конкретном клиенте.

При беге autorep -J ALL -q Я получаю следующий вывод:

 /* ----------------- ### ----------------- */

  insert_job: ###   job_type: CMD
  box_name: ###
  command: ###
  machine: MACHINE X
  owner: autosys
  permission:
  date_conditions: ###
  condition: ###
  description: ###
  box_terminator: 1
  alarm_if_fail: 0
  application: ###


  /* ----------------- ### ----------------- */

  insert_job: ###   job_type: CMD
  box_name: ###
  command: ###
  machine: MACHINE Y
  owner: autosys
  permission:
  date_conditions: ###
  condition: ###
  description: ###
  box_terminator: 1
  alarm_if_fail: 0
  application: ### 

  ...

Как видите, здесь отображается список ВСЕХ вакансий для ВСЕХ клиентов

Я ожидаю получить следующий результат:

 /* ----------------- ### ----------------- */

  insert_job: ###   job_type: CMD
  box_name: ###
  command: ###
  machine: MACHINE X
  owner: autosys
  permission:
  date_conditions: ###
  condition: ###
  description: ###
  box_terminator: 1
  alarm_if_fail: 0
  application: ###


  /* ----------------- ### ----------------- */

  insert_job: ###   job_type: CMD
  box_name: ###
  command: ###
  machine: MACHINE X
  owner: autosys
  permission:
  date_conditions: ###
  condition: ###
  description: ###
  box_terminator: 1
  alarm_if_fail: 0
  application: ### 

  ...

К сожалению команды autorep -J ALL -q -m MACHINE X не работает, но выдает следующий вывод:

/* ----------------- MACHINE X ----------------- */

insert_machine: MACHINE X
type: a
factor: 1.00
port: 7520
node_name: MACHINE X
agent_name: WA_AGENT
encryption_type: DEFAULT
opsys: windows
character_code: ASCII

Я думаю, что это формат JIL для добавления машины, так что я не ожидаю получить.

Знаете ли вы, возможно ли то, что я пытаюсь сделать, используя только команды autosys, или мне нужно проанализировать первый вывод через некоторое регулярное выражение, чтобы, наконец, получить то, что я хотел бы?

3 ответа

Решение

Я наконец-то создал скрипт, который делает это для меня:

#!/bin/ksh
autorep -j ALL -q > alljobs.jil
mkdir /tmp/autosystemp
i=0
while IFS=\| read -r "line"; do
        if [ `echo $line | grep '/* ------' | wc -l` -eq 1 ]; then
                i=$((i+1))
        fi
        echo "$line" >> "/tmp/autosystemp/f$i"
done < alljobs.jil
rm tempo/f0
for file in /tmp/autosystemp/*; do
        while read line; do
                if [ `echo $line | grep "machine: $1" | wc -l` -eq 1 ]; then
                        cat $file >> "jobs-on-$1.jil"
                fi
        done < $file
done
rm -rf /tmp/autosystemp

Чтобы использовать его, просто передайте имя машины в качестве аргумента скрипту

Я создал парсер Autosys Jill, используя который вы можете иметь необходимую информацию в CSV-файле. После этого вы можете отфильтровать необходимую информацию

Сначала вы должны иметь файл, который содержит необходимые столбцы, которые будут извлечены из Джилл, как

$]cat Jill_Columns
insert_job
job_type
box_name
watch_file
watch_interval
command
date_conditions
machine
owner
permission
condition
days_of_week
exclude_calendar
start_times
description
std_out_file
std_err_file
alarm_if_fail
profile
application

и файл Джилл, который должен быть проанализирован в CSV

Вот сценарий

Команда для запуска в окне Unix

sh JillToCsv.sh Your_Jill_Columns Yours_Jill_file

#!/bin/bash



Usage()
{
echo "----------------------------------------------------------------------------"
echo " "
echo " "
echo " "
echo "This script takes two parameter "
echo "First is the file which conatins column names like below for Jill information "
echo "cat Jill_ColumnOrder.txt"
echo "insert_job
job_type
box_name
command
date_conditions
machine
owner
permission
condition
days_of_week
exclude_calendar
start_times
description
std_out_file
std_err_file
alarm_if_fail
profile
application"

echo " "
echo " "
echo " "
echo "Second is the Jill File which needs to be parsed as csv "
echo " "
echo " "
echo " "
echo "----------------------------------------------------------------------------"
}

if [ $# -eq 2 ]
then
echo "File which contains column names  : $1"
echo "Input Jill File                   : $2"
else
echo "Please pass manadatory parameters"
Usage
exit 1
fi


Jill_ColumnOrder=$1


tfile=$2

dos2unix $tfile

final=${tfile}_Parse.csv
rm -f $final


heading=`cat $Jill_ColumnOrder|sed 's/$/@Akhilesh@/g'|sed '$ s/@Akhilesh@$//g'|tr -d '\n'`

line=
filler=1


no_columns=`cat $Jill_ColumnOrder|wc -l`


while [ $filler -lt $no_columns ]
do
        filler=`expr $filler + 1`
        line=$line`echo -n "@Akhilesh@"`
        #echo $line
done

#echo "$heading"
#echo "   "
#echo "$line"



echo "$heading">$final



count=1
cat $tfile|sed -r 's/job_type/\njob_type/g'|sed '/^$/d'|sed -r 's/\s+/ /g'|while read kk
do
        echo "$kk"|sed -r 's/^[ ]+//g'|grep '\/\* -----------------' # >/dev/null
        if [ $? -eq 0 ]
        then
                count=`expr $count + 1`
                echo "$line">>$final
        else
        PP=`echo $kk|cut -d ':' -f1|tr -d ' '`
        #echo "PP    : $PP"
        val=`echo $kk|cut -d ':' -f2-|sed -r 's/^[ ]+//g'|tr -d '"'|tr -d '\n'`
        #echo $val
        val=\"$val\"
        field=`grep -nw $PP $Jill_ColumnOrder|cut -d':' -f1|tr -d '\n'`

        #echo "field   :  $field"

        if [ -z $field ]
        then
        echo "$PP not there in column list"
        else

        awk -F'@Akhilesh@' -v OFS=@Akhilesh@ -v var="$val" -v var1=$count '{if(NR== var1) $'$field' = var;print}' $final > tmp.parse && mv tmp.parse $final
        fi



        fi
done




cat $final|sed 's/@Akhilesh@/,/g' > tmp.parse && mv tmp.parse $final

autorep пока не поддерживает эту сортировку. Вам нужно будет разобрать вывод.

Дейв

Другие вопросы по тегам