PHWinfo banniere

Titres
PORTAIL ANNUAIRE ARTICLES COMPARATEUR HÉBERGEURS DEVIS FORUMS RÉDUCTEUR D'URL
Précédent   PHWinfo > Forums Hébergement > Forum Serveur - Sécurité et techniques > comp.unix.shell > Misterious command output
S'inscrire FAQ Membres Recherche Messages du jour Marquer les forums comme lus
comp.unix.shell Using and programming the Unix shell.

Misterious command output

Réponse
 
LinkBack Outils de la discussion
Vieux 24/03/2008, 17h03   #1
Javi
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Misterious command output

Hi,

Take the follow commands (debian sid bash shell):

n=0;
while [ $n -lt 1000 ];
do
ldapsearch -x -h ldap -b 'dc=company,dc=com' uid |
tee /var/tmp/ldap-search.$n |
grep ^uid |
awk '{print $2}' |
sort |
{ tee a | head -1 ; tail -9 a; rm a; } |
md5sum
((n++));
done | sort | uniq -c

Result:
15 01755713a62aa7e6c22a56e3b1d8f140 -
2 bcdfba835b152d70f78018b1bf9c05b1 -
983 c5b4e951bb8a73809be2a4b69789f831 -

And all ldapsearch output are the same:
md5sum /var/tmp/ldap-search.* | uniq -w32
bded37d641d33fb9b47b58e47c8a1a1a /var/tmp/ldap-search.0

If I delete "{tee a | head -1; tail -9 a ; rm a; } " from the command
then I get the correct output (all the outputs is the same):
1000 b0ffe3bcb3569e81e6e9a0f319e462a5 -

Do you know why could be this issue ?

Thanks in advanced
  Réponse avec citation
Vieux 24/03/2008, 17h31   #2
Stephane CHAZELAS
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: Misterious command output

2008-03-24, 09:03(-07), Javi:
[...]
> Take the follow commands (debian sid bash shell):
>
> n=0;
> while [ $n -lt 1000 ];
> do
> ldapsearch -x -h ldap -b 'dc=company,dc=com' uid |
> tee /var/tmp/ldap-search.$n |
> grep ^uid |
> awk '{print $2}' |
> sort |
> { tee a | head -1 ; tail -9 a; rm a; } |

[...]

tee may be killed by a SIGPIPE if "head" terminates before tee
manages to write everything.

You could do:

{ cat > a; head -1 a; tail -9 a; rm a; }

Or use sed '1!d' instead of "head -1" as it doesn't exit until
the whole input has been read.

--
Stéphane
  Réponse avec citation
Vieux 24/03/2008, 17h49   #3
Javi
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: Misterious command output

On Mar 24, 5:31pm, Stephane CHAZELAS <this.addr...@is.invalid> wrote:
> 2008-03-24, 09:03(-07), Javi:
> [...]> Take the follow commands (debian sid bash shell):
>
> > n=0;
> > while [ $n -lt 1000 ];
> > do
> > ldapsearch -x -h ldap -b 'dc=company,dc=com' uid |
> > tee /var/tmp/ldap-search.$n |
> > grep ^uid |
> > awk '{print $2}' |
> > sort |
> > { tee a | head -1 ; tail -9 a; rm a; } |

>
> [...]
>
> tee may be killed by a SIGPIPE if "head" terminates before tee
> manages to write everything.
>
> You could do:
>
> { cat > a; head -1 a; tail -9 a; rm a; }
>
> Or use sed '1!d' instead of "head -1" as it doesn't exit until
> the whole input has been read.

Thank you very much.
  Réponse avec citation
Réponse


Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are oui
Pingbacks are oui
Refbacks are oui


Fuseau horaire GMT +1. Il est actuellement 05h52.


Édité par : vBulletin® version 3.7.3
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0 RC5 Tous droits réservés.
Version française #16 par l'association vBulletin francophone
PHWinfo est un site Éducation Sans Frontières ©2000-2008
Ad Management by RedTyger
©Tous droits réservés par les parties respectives
Page generated in 0,10477 seconds with 11 queries