Warum zeigt mir grep eine Ausgabe an, die das Suchwort nicht enthält?

Warum zeigt mir grep eine Ausgabe an, die das Suchwort nicht enthält?

Ich möchte überprüfen, ob der Sensu-Dienst installiert ist. Ich habe diesen Befehl ausgeführt service --status-all| grep sensuund hier ist die Ausgabe

vagrant@vagrant-ubuntu-trusty-64:~$ service --status-all| grep sensu
 [ ? ]  apport
 [ ? ]  console-setup
 [ ? ]  cryptdisks
 [ ? ]  cryptdisks-early
 [ ? ]  dns-clean
 [ ? ]  irqbalance
 [ ? ]  killprocs
 [ ? ]  kmod
 [ ? ]  networking
 [ ? ]  ondemand
 [ ? ]  open-vm-tools
 [ ? ]  pppd-dns
 [ ? ]  rc.local
 [ ? ]  screen-cleanup
 [ ? ]  sendsigs
 [ ? ]  umountfs
 [ ? ]  umountnfs.sh
 [ ? ]  umountroot
 [ ? ]  virtualbox-guest-x11

Ich finde es sehr merkwürdig, dass grepnicht alle obigen Zeilen herausgefiltert werden, da keine davon das Suchwort 'sensu' enthält.

Die Frage ist: Warum?

Antwort1

Es sieht so aus, als würden einige Dienste ihren Status an stderr melden:

$ service --status-all 2>&1 | wc -l
43
$ service --status-all 2>/dev/null | wc -l
28
$ service --status-all 2>&1 1>/dev/null | wc -l
15

28 an stdout, 15 an stderr. Sie sehen diejenigen, die an stderr berichten, weil die Pipe nur stdout verarbeitet. Tun Sie stattdessen Folgendes:

service --status-all 2>&1| grep sensu

verwandte Informationen