nginx: файл конфигурации / etc/nginx / nginx.ошибка теста conf (хост не найден в восходящем потоке)
у меня есть бродячий ящик, который когда-то работал нормально, и сегодня по какой-то причине я получаю следующее, Когда я пытаюсь перезапустить nginx.
nginx: [emerg] host not found in upstream "www.myclass.com.192.168.33.10.xip.io" in /etc/nginx/conf.d/myclass.com.conf:19
nginx: configuration file /etc/nginx/nginx.conf test failed
Я ничего не изменил, насколько мне известно (если только Центр обновления Windows не сделал что-то странное)
может ли кто - нибудь предложить, как заставить nginx работать снова и позволить мне перезапустить службу nginx-казалось бы, я не могу пинговать хост... есть идеи почему?
вот мой nginx conf файл: файл nginx conf
--обновление-- Выполните следующее, чтобы проверить, что находится на порту 80.. (прочитав еще один подобный пост), и я вижу, что демон лака находится на порту 80.. это причина проблемы?? Любые советы будут приветствоваться, поскольку я новичок в этом материале
sudo netstat -tlnp | grep 80
моего класса MyClass.ком.файл conf
server {
listen 80;
server_name class.com.* www.class.com.*;
root /vagrant/www.class.com/public_html;
index index.php;
access_log /vagrant/log/class.com.access.log;
error_log /vagrant/log/class.com.error.log error;
charset utf-8;
location = /favicon.ico { log_not_found off; access_log off; }
location = /robots.txt { access_log off; log_not_found off; }
error_page 404 /index.php;
location /socket.io {
proxy_pass http://www.class.com.192.168.33.10.xip.io:8055;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_http_version 1.1;
}
location / {
try_files $uri $uri/ @handler;
expires 30d;
}
location /. {
return 404;
}
location @handler {
rewrite / /index.php last;
}
location ~ .php/ {
rewrite ^(.*.php)/ last;
}
location ~ .php$ {
try_files $uri =404;
expires off;
fastcgi_read_timeout 900;
fastcgi_index index.php;
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param CLASS_ENVIRONMENT LYLE;
include /etc/nginx/fastcgi_params;
}
gzip on;
gzip_min_length 1000;
gzip_proxied any;
gzip_types text/plain application/xml text/css text/js application/x-javascript;
sendfile off;
}
3 ответов
все, что вам нужно, это поставить преобразователь, который может разрешить такое доменное имя:
resolver 8.8.8.8 valid=300s;
resolver_timeout 10s;
Google DNS (8.8.8.8) может разрешить его, но он разрешает внутренний адрес принадлежит сетевому классу C.
$ dig @8.8.8.8 www.class.com.192.168.33.10.xip.io
;; ANSWER SECTION:
www.class.com.192.168.33.10.xip.io. 299 IN A 192.168.33.10
ваша проблема исходит из этой строки:
proxy_pass http://www.class.com.192.168.33.10.xip.io:8055;
скорее всего, сервер испытывает трудности с разрешением этого DNS-имени. Вы также можете посмотреть на https://serverfault.com/questions/341810/nginx-failing-to-resolve-upstream-names-on-reload-even-if-they-do-resolve-by-the
немного поздно, возможно, но есть простое решение. Изменить
www.class.com.192.168.33.10.xip.io
на
www.class.com.192.168.33.10.nip.io
и он должен разрешаться на любом DNS.