roteiro original:

roteiro original:

Alguém forneceu este script para rotação de log. Eu quero saber qual é a lógica por trás disso. Embora eu entenda tudo, exceto --exec, o que foi um pouco confuso para mim.

roteiro original:

#!/bin/bash

set -x
NOW=$(date +"%m-%d-%Y")
echo $
cd /home/cloud360mssadmin/
find Tahoe-Broadcast.log.*  -exec sh -c 'mv "$0" "/home/cloud360mssread/$0-`date +"%d-%m-%Y"`"' {} \;

Acho que está faltando a variável 'echo $'.

O mesmo script que implementei de maneira diferente (apenas para fins de teste) que foi executado com sucesso.

#!/bin/bash
# this is scrpt for the log rotation
set -x
cd /var/log
echo " we are enter the `pwd`"
NOW="$(date +'%d-%m-%y')"
echo $NOW
find vmware* -exec mv '{}'  /home/vinod/ \;
cd /home/vinod/
find vmware* -exec tar -rvf vmware.tar {} \;

Minha tarefa é girar o log e compactá-lo.

Responder1

Tentar:

sh -c 'echo 0:$0, 1:$1, 2:$2' one two three

isso produz:

0:one, 1:two, 2:three

Em outras palavras, sh -clança um script temporário ( echo 0:$0, 1:$1, 2:$2) que recebe o restante dos argumentos de shcomo seus próprios argumentos. Normalmente, o primeiro desses argumentos é considerado um nome de comando (mas isso é uma convenção).

Então, no seu script:

-exec sh -c 'mv "$0" "/home/cloud360mssread/$0-`date +"%d-%m-%Y"`"' {} \;

está executando:

mv {the_file} /home/cloud360mssread/{the_file}-{timestamp}

o que é um pouco artificial, pois:

-exec mv "{}" "/home/cloud360mssread/{}-$(date +"%d-%m-%Y")" \;

teria funcionado tão bem.

informação relacionada