Ativar o armazenamento em cache no nginx

3

Eu tenho meu próprio VPS com o CentOS 6 e o nginx e quero ativar o armazenamento em cache. Para testá-lo, se ele for ativado com sucesso, uso o Google PageSpeed Insight. Meu problema é que eu não tenho muita experiência onde eu tenho que habilitar o cache e onde posso definir quanto tempo uma imagem, por exemplo, é armazenada em cache e assim por diante. Isso é o que eu encontrei na internet e tentei até agora:

  1. criando diretórios: /etc/nginx/sites-available e /etc/nginx/sites-enabled porque eles não existiam de alguma forma.
  2. Vinculando os diretórios criados aqui: /etc/nginx/nginx.conf com a adição de include /etc/nginx/sites-enabled/*; no final do arquivo, mas antes do último }
  3. Criando o arquivo /etc/nginx/sites-available/my-site.com.conf :

    server {
    listen       80;
    server_name  localhost;
    
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
    
    location ~*  \.(jpg|jpeg|png|gif|ico|css|js)$ {
        expires 15d;
    }
    
    location ~*  \.(pdf)$ {
        expires 30d;
    }
    

    }

  4. Vinculando o arquivo conf: ln -s /etc/nginx/sites-available/my-site.com.conf /etc/nginx/sites-enabled/my-site.com.conf

  5. do service nginx restart

Eu uso meu site para WordPress.

Então, sempre que eu testo minha página com o PageSpeed Insight ou outras ferramentas de velocidade de páginas, ele diz que eu não uso o cache para meu header.png, javascripts e assim por diante. Mas eu não recebo alguns erros, mesmo se eu verificar os arquivos de configuração com nginx -t , o que mostra isso:

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Eu esqueci alguma coisa?

Esta é a minha configuração completa do nginx: link

A default.conf da pasta conf.d : link

    
por Peter 03.03.2015 / 23:36

1 resposta

3

Você precisa adicionar as diretivas de armazenamento em cache ao seu arquivo default.conf e remover esse novo arquivo criado por você.

Seu novo arquivo é usado somente quando os usuários visitam o site usando http://localhost . Além disso, sua nova configuração de arquivos está usando caminhos diferentes em comparação ao seu arquivo default.conf .

Além disso, a diretiva root dentro de um bloco location é uma prática ruim.

Então, seu default.conf deve ficar assim:

#
# The default server
#
server {
    listen       80 default_server;
    server_name  213.165.xx.xx;

    #charset koi8-r;

    #access_log  logs/host.access.log  main;

    # Load configuration files for the default server block.
    include /etc/nginx/default.d/*.conf;

    root   /var/www/wordpress;

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

        try_files $uri $uri/ /index.php?q=$request_uri;

    }

    location ~*  \.(jpg|jpeg|png|gif|ico|css|js)$ {
        expires 15d;
    }

    location ~*  \.(pdf)$ {
        expires 30d;
    }

    location /admin {
        auth_basic "Administrator Login";
        auth_basic_user_file /var/www/admin/.htpasswd;
    }

    #!!! IMPORTANT !!! We need to hide the password file from prying eyes
    # This will deny access to any hidden file (beginning with a .period)
    location ~ /\. { deny  all; }

    error_page  404              /404.html;
    location = /404.html {
        root   /usr/share/nginx/html;
    }

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }


    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ \.php$ {
        root           /var/www/wordpress;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}
    
por 04.03.2015 / 12:52