私はNginx 1.6.2(PPAパッケージ)を実行していnginx-full
ますnginx/stable
。変更されていない設定を使用しています/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/*;
}
次のサイト構成をインポートして次に接続した場合sites-enabled
:
# /etc/nginx/sites-available/serve-files
server {
listen unix:/run/serve-files.socket;
root /var/www/files;
location / {
try_files $uri =404;
}
}
nginxを再起動し(使用して)、sudo service nginx restart
次の権限でソケットを作成します。/run/serve-files.socket
srw-rw-rw- 1 root root 0 Oct 29 14:35 serve-files.socket
その後、nginxを停止すると(を使用してsudo service nginx stop
)ソケットが予期しないままになります。 nginxバックアップを開始すると(使用してsudo service nginx start
)、次のエラーレポートが表示されます/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()
nginxは最後の閉じた後に残ったソケットを上書きしないようです。なぜこれですか?私が間違って設定したのでしょうか?この問題を解決する方法はありますか?
注:nginxを実行している他のサイトはありません。 nginxを停止すると遅延プロセスはなく、14.04.1 LTSを実行しているUbuntuサーバーとデスクトップでそれを再現しました。
更新:nginxが実行されている場合は、netstat -lx | grep serve-files
ソケットが使用中であることを示します。
unix 2 [ ACC ] STREAM LISTENING 6543310 /run/serve-files.socket
nginxが停止すると、netstat -lx | grep serve-files
ソケットは(予想どおり)使用されませんが、ソケットファイルは/run/serve-files.socket
。
ベストアンサー1
Nginxのドキュメントによると、信号出口「正常終了」が行われます。信号用語「クイックシャットダウン」が実行されます。最小バージョン1.8.0以降、Nginxはクラッシュしたときに古いUNIXドメインソケットを残します。信号出口信号。ただし、次のコマンドを使用すると、UNIXドメインソケットが正しく削除されます。信号用語信号。
/etc/init.d/nginx
PPAが提供するNginxサービススクリプトnginx/stable
が送信されます。信号出口sudo service nginx stop
Nginxが使用中または停止したときにNginxに送信されますrestart
。スクリプトにパッチを適用するには、次の行を修正してください。
STOP_SCHEDULE="${STOP_SCHEDULE:-QUIT/5/TERM/5/KILL/5}"
到着する:
STOP_SCHEDULE="${STOP_SCHEDULE:-TERM/5/KILL/5}"
しかし、UbuntuリポジトリのNginxサービススクリプトはすでに信号用語変える信号出口修正は必要ありません。