demon lakieru nie nasłuchuje na skonfigurowanym porcie

11

Próbuję zainstalować lakier na Ubuntu 16.04,

Przeczytałem kilka artykułów, z których żaden nie działa. Z tego, co przeczytałem, od Ubuntu 15.04 zmienił się sposób konfigurowania lakieru (z powodu systemd).

Teraz mam prawdziwy bałagan, który nie działa:


/ etc / default / varnish:

DAEMON_OPTS="-a :80 \
             -T localhost:6082 \
             -f /etc/varnish/default.vcl \
             -S /etc/varnish/secret \
             -s malloc,256m"

/etc/varnish/default.vcl (zwykle wskazuje host wskazujący na 127.0.0 i port 8080, ale dla celów debugowania zmodyfikowałem go do domeny zewnętrznej) vcl 4.0;

# Default backend definition. Set this to point to your content server.
backend default {
    .host = "www.varnish-cache.org"; 
    .port = "80";
}

/etc/apache2/ports.conf

Listen 8080

grep -R 'ExecStart=/usr/sbin/varnishd' /etc/

/etc/systemd/system/varnish.service:ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m
/etc/systemd/system/varnish.service.d/customexec.conf:ExecStart=/usr/sbin/varnishd -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m
/etc/systemd/system/multi-user.target.wants/varnish.service:ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m

/lib/systemd/system/varnish.service:

  GNU nano 2.5.3                                                Fichier : /lib/systemd/system/varnish.service                                                                                                      

[Unit]
Description=Varnish HTTP accelerator
Documentation=https://www.varnish-cache.org/docs/4.1/ man:varnishd

[Service]
Type=simple
LimitNOFILE=131072
LimitMEMLOCK=82000
ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m
ExecReload=/usr/share/varnish/reload-vcl
ProtectSystem=full
ProtectHome=true
PrivateTmp=true
PrivateDevices=true

[Install]
WantedBy=multi-user.target

service --status-all | grep varnish

 [ - ]  varnish
 [ + ]  varnishlog
 [ + ]  varnishncsa

po

sudo service varnish stop
sudo service varnish start

Usługa lakierowania nie nasłuchuje http://127.0.0.1:80/, przed ponownym uruchomieniem nasłuchuje, http://127.0.0.1:6081/ale już nie działa ... Nie wiem, co robić więcej ...




EDYCJA: po ponownym uruchomieniu nic nie działa,

Jeśli zrobię : systemctl status varnish

● varnish.service - Varnish HTTP accelerator
   Loaded: loaded (/etc/systemd/system/varnish.service; enabled; vendor preset: enabled)
  Drop-In: /etc/systemd/system/varnish.service.d
           └─customexec.conf
   Active: inactive (dead) since jeu. 2017-01-05 14:48:09 CET; 1s ago
     Docs: https://www.varnish-cache.org/docs/4.1/
           man:varnishd
  Process: 5077 ExecStart=/usr/sbin/varnishd -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m (code=exited, status=0/SUCCESS)
 Main PID: 5077 (code=exited, status=0/SUCCESS)

janv. 05 14:48:09 xubuntu-16 systemd[1]: Started Varnish HTTP accelerator.

service --status-all | grep varnish

 [ - ]  varnish
 [ - ]  varnishlog
 [ - ]  varnishncsa

jeśli ja sudo:, varnishd -d -f /etc/varnish/default.vclwtedy startwszystko działa dobrze ... dopóki nie wyjdę z cli


rozwiązany dzięki odpowiedzi @Gerald Schneider. Podaję kroki, które musiałem zrobić:

sudo apt remove varnish
sudo apt-get purge varnish
# I manually remove the 3 files in created in /etc/systemd/system/*
sudo apt install varnish
sudo nano /lib/systemd/system/varnish.service # put the rigth conf
sudo nano /etc/varnish/default.vcl #put the rigth conf
sudo systemctl daemon-reload
sudo service varnish restart

i wszystko działa dobrze! magia jest w /lib/systemd/system/varnish.servicepliku, inne zasoby online, które znalazłem, zmusiły mnie do myślenia, że ​​jest gdzie indziej, więc uważaj na internetowe (nieaktualne) samouczki!

Bruno
źródło
Prawdopodobnie potrzebne, aby po prostu usunąć poprzednią pozycję ->. /etc/systemd/system/varnish.service
Mike Q

Odpowiedzi:

17

Musisz także zmienić parametry początkowe lakieru w definicji usługi systemowej. Możesz edytować wiersz zaczynający się od ExecStartw pliku definicji usługi:

sudo vi /lib/systemd/system/varnish.service

Modyfikacja tego pliku ma jednak tę wadę, że nie zostanie zaktualizowany w przyszłych aktualizacjach pakietu. Alternatywnie, jak sugerowano w komentarzach, można utworzyć systemowy plik zrzutu , który jest preferowanym sposobem dodawania ustawień do definicji systemowych.

# create the drop in directory
sudo mkdir /etc/systemd/system/varnish.service.d
# create the drop in file. The name is irrelevant, as long as it ends in .conf
sudo vi /etc/systemd/system/varnish.service.d/mysettings.conf

Tutaj musisz tylko dodać ustawienia, które chcesz zmienić, wszystko inne zostanie załadowane z domyślnego pliku definicji.

Przykład:

[Service]
ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m

To jest domyślna linia, zmień ją w razie potrzeby

Następnie powiedz systemctl, aby ponownie załadował pliki konfiguracyjne i zrestartował usługę

sudo systemctl daemon-reload
sudo service varnish restart

Lakier powinien teraz nasłuchiwać na porcie 80.

Gerald Schneider
źródło
Zrobiłem to, ten plik zawiera:[...] [Unit] Description=Varnish HTTP accelerator Documentation=https://www.varnish-cache.org/docs/4.1/ man:varnishd [Service] Type=simple LimitNOFILE=131072 LimitMEMLOCK=82000 ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T localhost:6082 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m ExecReload=/usr/share/varnish/reload-vcl [...]
Bruno
Może powinieneś przywrócić domyślne pliki konfiguracyjne dla apache i lakieru i zacząć od nowa. Skonfigurowałem to do testowania i musiałem tylko zmienić konfigurację apache, aby nasłuchiwać na porcie 8080 i pojedynczej linii w varnish.service. Nic więcej.
Gerald Schneider
dzięki, zadziałało! Dodam kroki do odinstalowania w moim poście
Bruno
To jest złe podejście. Pliki jednostek systemowych w / lib / systemd nie powinny być edytowane, należy je przesłonić plikami rozwijanymi w / etc / systemd
Stephen
1
systemctl edit varnish.service automatyzuje tworzenie dla Ciebie rozwijanych opcji zastępowania plików jednostkowych
HBruijn,
5

Zauważ, że drop-in powinien mieć pusty ExecStart = W przeciwnym razie pojawi się błąd podczas uruchamiania usługi (duplikat ExecStart)

sudo mkdir /etc/systemd/system/varnish.service.d
sudo nano /etc/systemd/system/varnish.service.d/varnishd.conf

Z

[Service]
ExecStart=
ExecStart=/usr/sbin/varnishd -j unix,user=vcache -F -a :80 -T <YOUR WEBSERVER IP>:8081 -f /etc/varnish/default.vcl -S /etc/varnish/secret -s malloc,256m
Jerzy
źródło