Então estou tentando seguir isso aqui:
exceto no último raspberry pi. Acho ou pensei que tinha tudo configurado corretamente...
Nesse tutorial acima, você pode criar um projeto django para executá-lo no gunicorn e até testá-lo com:
ativando o env virtual e depois
cd ~/myproject
gunicorn --bind 0.0.0.0:8000 myproject.wsgi
Essa parte funciona, uma vez que aparece, é como se eu fizesse um python3 manage.py runserver 0.0.0.0:8000
eu posso então ir para o meu navegador e digitar o nome do host:
webserver2.abc.com:8000
e que todo o aplicativo funciona aparece.
Se eu parar o comando gunicorn e digitar desativar, tento executá-lo usando o .service que adicionei em /etc/systemd/system. Parece correr e um
sudo systemctl status gunicorn
● gunicorn.service - gunicorn daemon
Loaded: loaded (/etc/systemd/system/gunicorn.service; disabled; vendor preset: enabled)
Active: active (running) since Wed 2020-10-21 13:24:51 MDT; 50s ago
Main PID: 7645 (gunicorn)
Tasks: 4 (limit: 4915)
Memory: 55.0M
CGroup: /system.slice/gunicorn.service
├─7645 /home/pi/myvirtualenv_covid19/covid19env/bin/python /home/pi/myvirtualenv_covid19/covid19env/bin/gunicorn --workers 3 --bind unix:/tmp/covid19.sock covid19.wsgi:application
├─7651 /home/pi/myvirtualenv_covid19/covid19env/bin/python /home/pi/myvirtualenv_covid19/covid19env/bin/gunicorn --workers 3 --bind unix:/tmp/covid19.sock covid19.wsgi:application
├─7652 /home/pi/myvirtualenv_covid19/covid19env/bin/python /home/pi/myvirtualenv_covid19/covid19env/bin/gunicorn --workers 3 --bind unix:/tmp/covid19.sock covid19.wsgi:application
└─7653 /home/pi/myvirtualenv_covid19/covid19env/bin/python /home/pi/myvirtualenv_covid19/covid19env/bin/gunicorn --workers 3 --bind unix:/tmp/covid19.sock covid19.wsgi:application
Oct 21 13:24:51 webserver2 systemd[1]: Started gunicorn daemon.
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7645] [INFO] Starting gunicorn 20.0.4
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7645] [INFO] Listening at: unix:/run/gunicorn.sock (7645)
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7645] [INFO] Using worker: sync
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7651] [INFO] Booting worker with pid: 7651
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7652] [INFO] Booting worker with pid: 7652
Oct 21 13:24:51 webserver2 gunicorn[7645]: [2020-10-21 13:24:51 -0600] [7653] [INFO] Booting worker with pid: 7653
Confirmar.
Portanto, parece estar em execução, embora ir para webserver2.abc.com:8000 novamente não funcione desta vez e aqui está o gunicorn.service em /etc/systemd/system
[Unit]
Description = gunicorn daemon
Requires=gunicorn.socket
After=network.target
[Service]
User=pi
WorkingDirectory=/home/pi/myvirtualenv_covid19/covid19
ExecStart=/home/pi/myvirtualenv_covid19/covid19env/bin/gunicorn --workers 3 --bind unix:/tmp/covid19.sock covid19.wsgi:application
Restart=always
[Install]
WantedBy=multi-user.target
Curioso, não há nenhuma porta para vincular? Talvez esteja faltando uma configuração extra no meu projeto django??
Então, em segundo lugar, fazer o nginx ver isso parece um problema, porque se eu for
http://webserver2.abc.com:8080/
Dá-me um gateway ruim 502. Geralmente me diz o erro no /var/log/nginx :
2020/10/21 13:33:11 [crit] 1836#1836: *65 connect() to unix:/tmp/covid19.sock failed (2: No such file or directory) while connecting to upstream, client: 10.75.1.245, server: , request: "GET / HTTP/1.1", upstream: "http://unix:/tmp/covid19.sock:/", host: "webserver2.abc.com:8080"
Parece que está sendo executado, mas nenhum arquivo sock em /tmp me leva a acreditar que o gunicorn não está sendo executado a partir do arquivo .service systemd/system
Portanto, parece que a meia não está sendo criada, embora o arquivo gunicorn.socket esteja configurado para ter um arquivo /run/gunicorn.sock que está lá. Apenas o arquivo /tmp/covid19.sock não é.
Eu sinto que estou perto só preciso de um pouco de ajuda para ligar os pontos.
(também meu nginx está configurado para ouvir na porta 8080, mas não vejo onde estou dizendo no meu arquivo gunicorn.service para que ele seja executado em 8080?)
e para completar meu arquivo covid19.conf de sites disponíveis em /etc/nginx/
server {
listen 8080;
location = /favicon.ico { access_log off; log_not_found off; }
location /static/ {
root /home/pi/myvirtualenv_covid19/covid19;
}
location / {
include proxy_params;
proxy_pass http://unix:/tmp/covid19.sock;
}
}
OK, acabei de configurar um Pi para servir meu aplicativo django usando as mesmas instruções (na verdade, encontrei sua pergunta antes de encontrar o guia digitalocean a seguir, pois sabia que não queria 20.04/upstart).
Seguir o guia funcionou bem para mim, então vou tentar ajudar. As coisas que eu notei para investigar são:
Eu não tinha o
requires=gunicorn.socket
lá no meu.Eu coloquei o arquivo de soquete no meu diretório pessoal para o meu usuário evitar problemas de permissão (eu já tive esse problema antes), então eu recomendo fazer isso.
O AFAIK gunicorn se comunica com o nginx através do soquete, portanto, não precisa ser informado a uma porta para ouvir - o nginx faz a escuta e depois passa isso para o gunicorn.
Acho que você pode precisar verificar os logs, mas acho que seria entre a linha extra no arquivo gunicorn.service e o local do soquete que seria o primeiro lugar para começar para mim; com essas coisas feitas (sem referência, soquete na pasta pessoal), eu tenho o meu funcionando sem problemas.
HTH