Nginx sempre informa "não encontrado"

1

Tentando executar uma configuração nginx, mas toda vez que eu visito o endereço, recebo "não encontrado" em vez do site de laravel que estou esperando.

O servidor funcionou bem antes de eu adicionar o vhost, então estou supondo que há algo mal configurado lá. Qualquer ajuda para identificar o erro seria apreciada.

Por favor, note que o site só pode ser acessado por IP, e é por isso que eu tenho o preenchimento IP 123.123.123.123 para server_name .

etc / nginx / nginx.conf:

listen 80;

user  nginx;

worker_processes 4;

worker_rlimit_nofile 200000;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

events {
    worker_connections 4000;

    use epoll;

    multi_accept on;
}

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    include  /etc/nginx/conf.d/*.conf;
    include  /etc/nginx/sites-enabled/*;
}

etc / nginx / site-available / mysite.conf:

server {
    server_name  123.123.123.123;
    access_log  /srv/www/mysite/logs/access.log;
    error_log  /srv/www/mysite/logs/error.log;
    root  /srv/www/mysite/public_html/public;
    rewrite_log  on;
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    access_log /var/log/nginx/access.log main buffer=16k;

    gzip  on;
    gzip_disable "MSIE [1-6]\.(?!.*SV1)";
    gzip_http_version 1.1;
    gzip_vary on;
    gzip_proxied any;
    #gzip_proxied expired no-cache no-store private auth;
    gzip_comp_level 6;
    gzip_buffers 16 8k;
    gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript text/x-js;

    open_file_cache max=200000 inactive=20s;
    open_file_cache_valid 30s;
    open_file_cache_min_uses 2;
    open_file_cache_errors on;

    sendfile on;

    tcp_nopush on;

    tcp_nodelay on;

    keepalive_timeout 90;

    keepalive_requests 100000;

    reset_timedout_connection on;

    client_body_timeout 30;

    send_timeout 30;

    # Remove trailing slash to please Laravel routing system.
    if (!-d $request_filename) {
        rewrite  ^/(.+)/$ /$1 permanent;
    }

    location / {
        index  index.html index.htm index.php;
    }

    location ~ \.php$ {
        try_files  $uri =404 $uri/ /index.php?$query_string;
        include  /etc/nginx/fastcgi_params;
        fastcgi_pass  127.0.0.1:9000;
        #fastcgi_pass  unix:/var/run/php5-fpm.sock;
        fastcgi_split_path_info  ^(.+\.php)(.*)$;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME /srv/www/mysite/public_html$fastcgi_script_name;
    }

    # We don't need .ht files with nginx.
    location ~ /\.ht {
        deny  all;
    }

    # Set header expirations.
    location ~* \.(?:ico|css|js|jpe?g|JPG|png|svg|woff)$ {
        expires  365d;
    }
}
    
por eComEvo 15.04.2014 / 06:46

2 respostas

1

Você inclui de / etc / nginx / sites-enabled / , portanto, certifique-se de adicionar uma nova configuração a / etc / nginx / site-available / está disponível a partir do último, por exemplo

ln -s /etc/nginx/sites-available/mysite.conf /etc/nginx/sites-enabled/mysite.conf

No seu arquivo mysite.conf também adiciona uma diretiva listen como

server {
    listen 123.123.123.123;
    server_name  123.123.123.123 "";
    ...
}

O "" é para pedidos de cabeçalho HOST vazios, apenas para ficar bem com isso.

Atualize mais testes:

Defina um access-default.log para o servidor principal e um access-mysite.log para que você possa ver quem diz "não encontrado" (não apenas os logs de erros).

Use também o wget para acessar todos os servidores (o seu IP-Server e o servidor proxy) e procure nos logs.

Adicione uma diretiva "root" ao local do servidor principal e tente acessar um arquivo não-proxy (como index.html) para ver quem acha que é o responsável.

Você pode, durante os testes, marcar também o servidor virtual como default_server para todas as solicitações ( consulte os documentos a>).

    
por 15.04.2014 / 08:43
0

No seu mysite.conf, adicione uma diretiva de escuta:

server {
listen 80 default;
server_name  123.123.123.123 "";
...

}

    
por 15.04.2014 / 08:57

Tags