Czy mogę zapobiec stronicowaniu wyników przez „status usługi” za pomocą „mniej”?


35

Jak zatrzymać service <name> statusużycie polecenia lessna wyjściu?

Mam skrypt, który automatyzuje niektóre akcje sysadmin, a po uaktualnieniu serwera do Ubuntu 16.04, łamie się, ponieważ akcje sprawdzające status usługi blokują, ponieważ używa czegoś w rodzaju lesswyświetlania wyników, a konkretnie supervisorusługi.

Mam kilka demonów skonfigurowanych do działania, a po uruchomieniu sudo service supervisor statusotrzymuję:

* 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

I nie powróci, dopóki ręcznie nie przewiń w dół lub nie naciśnij, Qaby wyjść. Jak mogę wyłączyć tę funkcję?

Odpowiedzi:


54

Ubuntu to systemowy system, w którym service statuspolecenie faktycznie wywołuje systemctl status, a systemctl ma --no-pageropcję, która robi dokładnie to, czego szukasz. Lepiej więc użyć prostego polecenia systemctl w skrypcie.

sudo systemctl --no-pager status supervisor

EDYCJA: env var SYSTEMD_PAGER

Innym sposobem, jak wskazał @jwodder, jest ustawienie zmiennej środowiskowej SYSTEMD_PAGER. Ma to tę dodatkową zaletę, że wpływa również na dane wyjściowe systemctlwywołania przez inną aplikację, taką jak service.

export SYSTEMD_PAGER=''
sudo service supervisor status

Umożliwi Ci osiągnięcie tej samej wydajności.


2
Chciałbym zasugerować umieszczenie opcji przed poleceniem:sudo systemctl --no-pager status supervisor
Jeff Schaller

edytowane w celu dopasowania do Twojej sugestii. dobrze postępować zgodnie z przeznaczeniem narzędzi. dzięki.
Tim Kennedy,

2
„Ubuntu to systemdsystem” ... kiedy Upstart nie jest używany, to jest
cat

6
Aby systemctlzawsze zachowywać się tak, jak --no-pagerpodano, możesz ustawić SYSTEMD_PAGERzmienną środowiskową na jeden catlub pusty ciąg znaków.
jwodder

@jwodder - ustawienie SYSTEMD_PAGER ma tę dodatkową zaletę, że wpływa również na wydajność, systemctlnawet gdy zostanie wywołany przez service. Miły.
Tim Kennedy

34

less zwykle wyłączy tryb pagera, jeśli wykryje, że jego wyjście nie jest terminalem. Możesz więc spróbować, aby wyjście polecenia nie było terminalem, uruchamiając coś takiego:

sudo service supervisor status | cat

4
Ta odpowiedź jest dobra, ponieważ jest ogólna. Odpowiedź Tima Kennedy'ego jest dobra, ponieważ jest specyficzna systemctl. Głosowałem za obiema.
Kamil Maciorowski

Już prawie chciałem usunąć swoją odpowiedź na rzecz drugiej, ale widzę, jak ciekawostka z wiedzy ogólnej może być cenna. Dla przypomnienia, uważam, że drugą odpowiedzią powinna być ta, którą należy zaakceptować.
dhag

Zawsze wybiorę bardziej ogólną odpowiedź, przy czym wszystkie inne rzeczy będą takie same. Właśnie to zrobiłbym na RHEL, gdyby polecenie zaplecza szło do lessmnie i nie chciałem takiego zachowania. Oczywiście, gdybym robił to w skrypcie, który wyodrębnia coś w rodzaju linii „Active:”, to już nie byłby to terminal, a ten problem nawet by nie istniał.
Monty Harder

To lessniczego nie wyłącza. Po pierwsze, systemctlnie wywołuje on pagera, gdy jego standardowym wyjściem nie jest terminal.
JdeBP

@MontyHarder poza tym, że prawdopodobnie nie powinieneś wypisywać linii Active: ponieważ możesz po prostu sprawdzić kod wyjścia statusu systemctl (naprawdę powinieneś użyć systemctl show w skrypcie zamiast statusu) lub systemctl is- {active, failed} , który powie ci bez żadnego z tych parsowania BS :)
Yet Another User

16

Od 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").

Więc gdzieś w twoim środowisku zainicjuj, ustaw:

SYSTEMD_PAGER=

Miły. Fajną rzeczą jest to, że ustawienie SYSTEMD_PAGER wpływa również na inne programy, które wywołują systemctl! więc teraz service supervisor statuswykazuje to samo zachowanie.
Tim Kennedy

@ Toby przepraszam, ale wolę moje strony w blokach kodu.
muru

3

Będziesz także musiał zmodyfikować sudoersplik:

 Defaults        env_keep += "SYSTEMD_PAGER"

To bardzo przydatna informacja .. denerwowało mnie to, że po przełączeniu SYSTEMD_PAGER sudo systemctl status <service>wciąż był stronicowany .. +1
Procyclinsur 1'18
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.