簡體   English   中英

在nginx中使用prerender和proxy

[英]Using prerender with proxy in nginx

我正在嘗試使用prerender.io來獲取angularjs頁面的快照。 目前我有一個用於Web應用程序的NodeJS實例, nginx反向代理將請求從端口80重定向到4000

根據prerender nginx手冊( https://gist.github.com/thoop/8165802 ),我可以將搜索引擎機器人請求轉發給prerender url,但因為我已經有了NodeJS應用程序的代理,我不知道怎么能我prerender try_files指令。

我的問題是,我如何使用NodeJS應用程序代理和prerender指令?

我相信prerender的例子有答案。 如果prerender設置為1,則使用rewrite然后使用proxy_pass。

所以你會改變這個:

if ($prerender = 0) {
            rewrite .* /index.html break;
        }

對此:

if ($prerender = 0) {
        rewrite .* /index.html break;
        proxy_pass http://[INTERNAL IP]:[PORT];
    }

我會進一步修改,因為你使用Node並且不需要為靜態文件設置一些東西。

這是我的最終答案:

server {
   listen 80;
   server_name example.com;

   location / {
       try_files $uri @prerender;
   }

location @prerender {
    #proxy_set_header X-Prerender-Token YOUR_TOKEN;

    set $prerender 0;
    if ($http_user_agent ~* "baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") {
        set $prerender 1;
    }
    if ($args ~ "_escaped_fragment_") {
        set $prerender 1;
    }
    if ($http_user_agent ~ "Prerender") {
        set $prerender 0;
    }
    if ($uri ~ "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent|ttf|woff)") {
        set $prerender 0;
    }

    #resolve using Google's DNS server to force DNS resolution and prevent caching of IPs
    resolver 8.8.8.8;

    if ($prerender = 1) {

        #setting prerender as a variable forces DNS resolution since nginx caches IPs and doesnt play well with load balancing
        set $prerender "service.prerender.io";
        rewrite .* /$scheme://$host$request_uri? break;
        proxy_pass http://$prerender;
    }
    if ($prerender = 0) {
        proxy_pass http://[INTERNAL IP]:[PORT];
    }
}
} 

我希望有所幫助。 我要補充的一件事是我不會使用預渲染引擎。 蜘蛛可以做索引鏈接和使用javascript和PDF的頁面。

只是我的兩分錢。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM