Zmienna środowiskowa DEBIAN_FRONTEND

22

Mój potencjalny dostawca hostingu sugeruje uruchomienie polecenia w terminalu, aby zminimalizować obraz systemu operacyjnego serwera opartego na KVM. Ponieważ ich szablony KVM są dostarczane z pakietami, których nie będę potrzebował, pomyślałem, że mogę użyć tego samego polecenia do usunięcia niechcianych pakietów.

To polecenie zaczyna się od DEBIAN_FRONTEND=noninteractive, a następnie wywołuje apt-get removew następujący sposób:

DEBIAN_FRONTEND=noninteractive apt-get remove --purge -y -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" package-1 package-2 ... package-n; apt-get -y autoremove; apt-get clean all 

Po raz pierwszy napotykam DEBIAN_FRONTENDzmienną środowiskową i jak dotąd nie mogłem znaleźć użytecznych informacji. Zastanawiam się więc, co to noninteractiverobi i czy jest to wskazane, ponieważ przypuszczam, że ta wartość ( noninteractive) będzie się utrzymywać.

Asarluhi
źródło
4
Nie wiedząc, co robi, mogę powiedzieć, że kiedy ustawisz zmienną w ten sposób jako część dłuższego ciągu poleceń, będzie to skuteczne tylko podczas uruchamiania tego polecenia. To nie trwa.
Gunnar Hjalmarsson

Odpowiedzi:

27

Zwykłe wstawienie aptpolecenia za pomocą DEBIAN_FRONTEND=somethingnie trwa po pojedynczym poleceniu, do którego zostało zastosowane.

Te DEBIAN_FRONTENDopcje są udokumentowane w rozdziale 7 Podręcznik stron debconf(może trzeba zainstalować debconf-docpakiet w celu udostępnienia ich w systemie). Odman 7 debconf :

Frontends
   One of debconf's unique features is that the interface it  presents  to
   you is only one of many, that can be swapped in at will. There are many
   debconf frontends available:

   dialog The default frontend, this uses  the  whiptail(1)  or  dialog(1)
          programs to display questions to you. It works in text mode.

   readline
          The  most  traditional frontend, this looks quite similar to how
          Debian configuration always has been:  a  series  of  questions,
          printed  out  at  the console using plain text, and prompts done
          using the readline library. It even supports tab completion. The
          libterm-readline-gnu-perl package is strongly recommended if you
          chose to use this frontend; the default readline module does not
          support  prompting  with default values.  At the minimum, you'll
          need the perl-modules package installed to use this frontend.

          This frontend has some special hotkeys. Pageup (or ctrl-u)  will
          go  back  to  the previous question (if that is supported by the
          package that is using debconf), and pagedown  (or  ctrl-v)  will
          skip forward to the next question.

          This is the best frontend for remote admin work over a slow con‐
          nection, or for those who are comfortable with unix.

   noninteractive
          This is the anti-frontend. It never interacts with you  at  all,
          and  makes  the  default  answers  be used for all questions. It
          might mail error messages to root, but that's it;  otherwise  it
          is  completely  silent  and  unobtrusive, a perfect frontend for
          automatic installs. If you are using this front-end, and require
          non-default  answers  to questions, you will need to preseed the
          debconf database; see the section below  on  Unattended  Package
          Installation for more details.

Zauważa również, że:

   You can change the default frontend debconf uses by reconfiguring  deb‐
   conf.  On the other hand, if you just want to change the frontend for a
   minute, you can set the DEBIAN_FRONTEND  environment  variable  to  the
   name of the frontend to use. For example:

     DEBIAN_FRONTEND=readline apt-get install slrn

   The  dpkg-reconfigure(8) and dpkg-preconfigure(8) commands also let you
   pass --frontend= to them, followed by the frontend  you  want  them  to
   use.

   Note  that not all frontends will work in all circumstances. If a fron‐
   tend fails to start up for some reason, debconf will print out  a  mes‐
   sage explaining why, and fall back to the next-most similar frontend.
steeldriver
źródło
1
Widzę DEBIAN_FRONTEND=noninteractiveczęsto używane w Dockerfiles. Ta odpowiedź sprawia, że ​​zastanawiam się, dlaczego po prostu nie używamy --yesflagi z poleceniami apt, ponieważ będzie ona bardziej jednoznaczna iw większości przypadków spełni nasze potrzeby.
Dennis,
@Dennis Myślę, że to dlatego, że readline niekoniecznie jest zainstalowany i apt może wygenerować ostrzeżenie jako takie.
hayd
4
Uwaga: jeśli używasz DEBIAN_FRONTENDz sudo, ustaw zmienną wsudo poleceniu, a nie dla niego. Czyli: sudo DEBIAN_FRONTEND=noninteractive apt-get install slrn. Jeśli wcześniej wstawisz ustawienie zmiennej env sudo, będzie ono ważne dla samego sudopolecenia i sudonie skopiuje go do apt-geturuchamianego polecenia. Używanie go pomiędzy sudoa rzeczywistą komendą jest sudoskładnią do ustawiania zmiennych env dla komendy, która ma zostać uruchomiona (patrz strona man). To sprawiło mi trudność, więc pomyślałem o dzieleniu się.
caxcaxcoatl
1
Jeśli chcesz zmienić domyślne zachowanie interfejsu użytkownika noninteractive, możesz to zrobić za pomocą następującego polecenia:dpkg-reconfigure debconf --frontend=noninteractive
Carter Pape,