У меня есть сервер, на котором работает nginx с лаком. Я не могу запустить nginx и varnish одновременно с тем, что они оба пытаются прослушивать порт 80.
nginx настроен на прослушивание порта 8080
upstream www {
server 127.0.0.1:9001;
}
server {
listen 8080 default_server;
server_name server.com;
root /var/www/html/;
location /docs/index.php {
fastcgi_pass www;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param HTTPS off;
fastcgi_param SERVER_PORT 8888;
}
}
Затем Varnish прослушивает порт 80
NFILES=131072
MEMLOCK=82000
NPROCS="unlimited"
RELOAD_VCL=1
VARNISH_VCL_CONF=/etc/varnish/default.vcl
VARNISH_LISTEN_PORT=80
VARNISH_ADMIN_LISTEN_ADDRESS=127.0.0.1
VARNISH_ADMIN_LISTEN_PORT=6082
VARNISH_SECRET_FILE=/etc/varnish/secret
VARNISH_MIN_THREADS=50
VARNISH_MAX_THREADS=1000
VARNISH_THREAD_TIMEOUT=120
VARNISH_STORAGE_FILE=/var/lib/varnish/varnish_storage.bin
VARNISH_STORAGE_SIZE=1G
VARNISH_STORAGE="file,${VARNISH_STORAGE_FILE},${VARNISH_STORAGE_SIZE}"
VARNISH_TTL=120
DAEMON_OPTS="-a ${VARNISH_LISTEN_ADDRESS}:${VARNISH_LISTEN_PORT} \
-f ${VARNISH_VCL_CONF} \
-T ${VARNISH_ADMIN_LISTEN_ADDRESS}:${VARNISH_ADMIN_LISTEN_PORT} \
-t ${VARNISH_TTL} \
-w ${VARNISH_MIN_THREADS},${VARNISH_MAX_THREADS},${VARNISH_THREAD_TIMEOUT} \
-u varnish -g varnish \
-S ${VARNISH_SECRET_FILE} \
-s ${VARNISH_STORAGE}"
Когда я пытаюсь перезапустить nginx, я получаю сообщение об ошибке
service nginx restart
Stopping nginx: [FAILED]
Starting nginx: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] still could not bind()
Если я остановлю лак и запустил netstat, я увижу, что nginx работает на портах 8080 и 80.
netstat -tulpn | grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 95831/nginx
tcp 0 0 0.0.0.0:8080 0.0.0.0:* LISTEN 95831/nginx
Проверяя каталог конфигурации nginx, я нигде не вижу, что порт определен
grep -rnw '/etc/nginx/' -e '80'
grep -rnw '/etc/nginx/' -e 'server'
/etc/nginx/nginx.conf.rpmnew:40: server {
/etc/nginx/nginx.conf.rpmnew:46: # Load configuration files for the default server block.
/etc/nginx/nginx.conf.rpmnew:52: # redirect server error pages to the static page /40x.html
/etc/nginx/nginx.conf.rpmnew:58: # redirect server error pages to the static page /50x.html
/etc/nginx/nginx.conf.rpmnew:70: # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
/etc/nginx/nginx.conf.rpmnew:88:# Settings for a TLS enabled server.
/etc/nginx/nginx.conf.rpmnew:90:# server {
/etc/nginx/nginx.conf.rpmnew:96:# ssl_certificate "/etc/pki/nginx/server.crt";
/etc/nginx/nginx.conf.rpmnew:97:# ssl_certificate_key "/etc/pki/nginx/private/server.key";
/etc/nginx/nginx.conf.rpmnew:107:# # Load configuration files for the default server block.
/etc/nginx/nginx.conf:40:# server {
/etc/nginx/nginx.conf:46:# # Load configuration files for the default server block.
/etc/nginx/nginx.conf:52: # redirect server error pages to the static page /40x.html
/etc/nginx/nginx.conf:58: # redirect server error pages to the static page /50x.html
/etc/nginx/nginx.conf:70: # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
/etc/nginx/nginx.conf:88:# Settings for a TLS enabled server.
/etc/nginx/nginx.conf:90:# server {
/etc/nginx/nginx.conf:96:# ssl_certificate "/etc/pki/nginx/server.crt";
/etc/nginx/nginx.conf:97:# ssl_certificate_key "/etc/pki/nginx/private/server.key";
/etc/nginx/nginx.conf:107:# # Load configuration files for the default server block.
/etc/nginx/conf.d/virtual.conf:5:#server {
/etc/nginx/conf.d/server.conf:2: server 127.0.0.1:9001;
/etc/nginx/conf.d/server.conf:4:server {
/etc/nginx/conf.d/server.conf:170:server {
/etc/nginx/nginx.conf.default:35: server {
/etc/nginx/nginx.conf.default:50: # redirect server error pages to the static page /50x.html
/etc/nginx/nginx.conf.default:63: # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
/etc/nginx/nginx.conf.default:84: #server {
/etc/nginx/nginx.conf.default:96: # HTTPS server
/etc/nginx/nginx.conf.default:98: #server {
Убедитесь, что все блоки сервера имеют директивы прослушивания, иначе nginx по умолчанию будет 80 для этого блока.