Estou executando o Nginx 1.6.2 (o pacote nginx-full
do nginx/stable
PPA). Estou usando a configuração não modificada /etc/nginx/nginx.conf
:
user www-data;
worker_processes 4;
pid /run/nginx.pid;
events {
worker_connections 768;
}
http {
##
# Basic Settings
##
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/mime.types;
default_type application/octet-stream;
##
# Logging Settings
##
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
##
# Gzip Settings
##
gzip on;
gzip_disable "msie6";
##
# Virtual Host Configs
##
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
Se eu fizer a seguinte configuração do site e vinculá-la a sites-enabled
:
# /etc/nginx/sites-available/serve-files
server {
listen unix:/run/serve-files.socket;
root /var/www/files;
location / {
try_files $uri =404;
}
}
E reinicie o nginx (usando sudo service nginx restart
), o soquete /run/serve-files.socket
é criado com as seguintes permissões:
srw-rw-rw- 1 root root 0 Oct 29 14:35 serve-files.socket
Se eu interromper o nginx (usando sudo service nginx stop
), o soquete permanecerá inesperadamente. E quando eu inicio o backup do nginx (usando sudo service nginx start
), recebo os seguintes erros relatados para /var/log/nginx/error.log
:
2014/10/29 14:36:32 [emerg] 21680#0: bind() to unix:/run/serve-files.socket failed (98: Address already in use)
2014/10/29 14:36:32 [emerg] 21680#0: bind() to unix:/run/serve-files.socket failed (98: Address already in use)
2014/10/29 14:36:32 [emerg] 21680#0: bind() to unix:/run/serve-files.socket failed (98: Address already in use)
2014/10/29 14:36:32 [emerg] 21680#0: bind() to unix:/run/serve-files.socket failed (98: Address already in use)
2014/10/29 14:36:32 [emerg] 21680#0: bind() to unix:/run/serve-files.socket failed (98: Address already in use)
2014/10/29 14:36:32 [emerg] 21680#0: still could not bind()
Parece que o nginx não sobrescreve seu soquete que foi deixado de seu desligamento anterior. Por que é isso? Eu confiei algo errado? Existe uma maneira de contornar isso?
NOTA: Não existem outros sites rodando com o nginx, quando eu paro o nginx não há processos remanescentes, e eu reproduzi isso em um servidor e desktop Ubuntu ambos rodando o 14.04.1 LTS.
ATUALIZAÇÃO: Quando o nginx estiver em execução, netstat -lx | grep serve-files
indicará que o soquete está sendo usado:
unix 2 [ ACC ] STREAM LISTENING 6543310 /run/serve-files.socket
Quando o nginx é interrompido, netstat -lx | grep serve-files
indica que nenhum soquete está sendo usado (como esperado), mas o arquivo de soquete permanece em /run/serve-files.socket
.