Posso impedire a "status foo service" di effettuare il paging dell'output tramite "less"?


35

Come si interrompe l' service <name> statusutilizzo del comando lesssul suo output?

Ho uno script che automatizza alcune azioni di amministratore di sistema e dopo aver aggiornato il mio server a Ubuntu 16.04, si sta rompendo perché le azioni che controllano lo stato del servizio si stanno bloccando perché sta usando qualcosa come lessmostrare l'output, in particolare il supervisorservizio.

Ho diversi demoni configurati per l'esecuzione e, quando eseguito sudo service supervisor status, ottengo:

* supervisor.service - Supervisor process control system for UNIX
   Loaded: loaded (/lib/systemd/system/supervisor.service; disabled; vendor preset: enabled)
   Active: active (running) since Mon 2017-02-06 20:35:34 EST; 12h ago
     Docs: http://supervisord.org
  Process: 18476 ExecStop=/usr/bin/supervisorctl $OPTIONS shutdown (code=exited, status=0/SUCCESS)
 Main PID: 20228 (supervisord)
   CGroup: /system.slice/supervisor.service
           |- 7387 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7388 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7389 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7390 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7391 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7392 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7393 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7394 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7395 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7396 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7397 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7398 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7678 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7679 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7680 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7681 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7682 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7683 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7684 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7685 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7693 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7694 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7698 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7702 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7703 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7705 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7707 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7709 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7710 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7712 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7713 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7717 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7720 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7723 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7724 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7728 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7730 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7731 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7733 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7734 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7735 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7738 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7743 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7747 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7748 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7750 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7752 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7756 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7758 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7761 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7763 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7764 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7772 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7781 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7785 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7794 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7799 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7801 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
           |- 7805 /usr/local//myproject/.env/bin/python2.7 /usr/local//myproject/.env/bin/celery worker -A /myproject -l info --autoreload
lines 1-66

E non ritorna finché non scorro manualmente verso il basso o premo Qper uscire. Come disabilito questa funzione?

Risposte:


54

Ubuntu è un sistema systemd, in cui il service statuscomando effettivamente chiama systemctl status, e systemctl ha --no-pagerun'opzione che fa esattamente quello che stai cercando. Quindi potresti stare meglio usando il comando straight systemctl nel tuo script.

sudo systemctl --no-pager status supervisor

EDIT: env var SYSTEMD_PAGER

Un altro modo, come sottolineato da @jwodder, è impostare la variabile d'ambiente SYSTEMD_PAGER. Questo ha l'ulteriore vantaggio di influenzare anche l'output di systemctlquando chiamato da un'altra applicazione simile service.

export SYSTEMD_PAGER=''
sudo service supervisor status

Ti permetterà di ottenere lo stesso risultato.


2
Vorrei suggerire di mettere l'opzione prima del comando:sudo systemctl --no-pager status supervisor
Jeff Schaller

modificato in base al tuo suggerimento. buono a seguire l'uso previsto degli strumenti. Grazie.
Tim Kennedy,

2
"Ubuntu è un systemdsistema" ... quando Upstart non è in uso, ovvero
cat

6
Per far sì che systemctlsi comporti sempre come --no-pagerindicato, è possibile impostare la SYSTEMD_PAGERvariabile di ambiente su una cato sulla stringa vuota.
jwodder,

@jwodder - l'impostazione SYSTEMD_PAGER ha l'ulteriore vantaggio di influenzare anche l'output di systemctlanche quando viene chiamato da service. Bello.
Tim Kennedy,

34

less normalmente disattiva la modalità cercapersone se rileva che il suo output non è un terminale. Quindi potresti provare a rendere l'output del tuo comando non-a-terminal eseguendo qualcosa del tipo:

sudo service supervisor status | cat

4
Questa risposta è buona perché è generica. La risposta di Tim Kennedy è buona perché è specifica systemctl. Ho votato entrambi.
Kamil Maciorowski il

Stavo quasi per cancellare la mia risposta a favore dell'altra, ma vedo come la conoscenza della conoscenza generica possa essere preziosa. Per la cronaca, penso che l'altra risposta dovrebbe essere quella da accettare.
Dhag,

Sceglierò sempre la risposta più generica, a parità di tutte le altre cose. Questo è esattamente ciò che farei su RHEL se il comando back-end lesslo volesse e non volessi quel comportamento. Ovviamente, se lo facessi in uno script che fa fuori qualcosa come la linea "Attivo:", non sarebbe già destinato a terminare e questo problema non esisterebbe.
Monty Harder,

Non sta lessspegnendo nulla. In systemctlprimo luogo non sta invocando un cercapersone quando il suo output standard non è un terminale.
JdeBP,

@MontyHarder oltre al fatto che probabilmente non dovresti estrarre la linea Active: perché puoi semplicemente controllare il codice di uscita dello stato di systemctl (in realtà dovresti usare systemctl show in uno script anziché lo stato) o systemctl è- {attivo, non riuscito} , che ti dirà senza nessuna di queste analisi BS :)
Ancora un altro utente il

16

Da man systemctl:

ENVIRONMENT
...
   $SYSTEMD_PAGER
       Pager to use when --no-pager is not given; overrides $PAGER.
       Setting this to an empty string or the value "cat" is equivalent to
       passing --no-pager.

   $SYSTEMD_LESS
       Override the default options passed to less ("FRSXMK").

Quindi, da qualche parte nell'inizializzazione dell'ambiente, imposta:

SYSTEMD_PAGER=

Bello. La cosa bella di questo è che l'impostazione SYSTEMD_PAGER influenza anche altri programmi che chiamano systemctl! così ora, service supervisor statusmostra lo stesso comportamento.
Tim Kennedy,

@ Mi dispiace, ma preferisco le mie manpage in blocchi di codice.
Muru,

3

Dovrai anche modificare il tuo sudoersfile:

 Defaults        env_keep += "SYSTEMD_PAGER"

Questa è un'informazione molto utile .. si stava irritando per il fatto che dopo aver cambiato SYSTEMD_PAGER, sudo systemctl status <service>era ancora impaginato .. +1
Procyclinsur
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.