2016-06-01 2 views
0

ローカル開発サーバーでテスト用にPrerenderを使用したいと考えています。 Flask(ウェブサイトのバックエンド)用のアプリケーションサーバーはlocalhost:5000上で実行されていますが、今はlocalhost:3000上にPrerenderサーバーを既に設定しています。ローカルテストサーバーでプレレンダーする

:事前レンダリングのためのGitHubページ は、それは私は2つの質問があるローカルサービスとして事前レンダリングを使用するために私はnginxの設定ファイル

server { 
    listen 80; 
    server_name example.com; 

    root /path/to/your/root; 
    index index.html; 

    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) { 
      rewrite .* /index.html break; 
     } 
    } 
} 

にも

export PRERENDER_SERVICE_URL=<your local url> 

とする必要があると述べています

1.Whatは

export PRERENDER_SERVICE_URL=<your local url> 

行うのでしょうか?そして、私は "あなたのローカルURL"を何に設定すべきですか?これは、Webサーバー用のアプリケーションサーバーのURL(localhost:5000)か、またはプレレンダーサーバーのURL(localhost:3000)である必要があります。

2.Iが含まれるように私のnginx.confを変更:

server { 
    listen 80; 
    server_name localhost:5000; 

    root /path/to/my/root; 
    index index.html; 

    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 "localhost:3000"; 
      rewrite .* /$scheme://$host$request_uri? break; 
      proxy_pass http://$prerender; 
     } 
     if ($prerender = 0) { 
      rewrite .* /index.html break; 
     } 
    } 
} 

をし、動作するようには思えません。 localhost(localhost:80)にアクセスすると404が見つかりません。 localhost:5000へのトラフィックのルーティングも正しくないようです。

私が間違っていることについてのアイデアはありますか?どうもありがとう!

答えて

0

nginx設定を使用しているので、PRERENDER_SERVICE_URLを使用する必要はありません。あなたの場合は何もしません。

service.prerender.iolocalhost:3000をnginx configのように変更することは、ローカルのプレレンダリングサーバーを指す正しい方法です。

nginxは正しく設定されていませんが、おそらく、index.htmlをlocalhost:5000のproxy_passに書き換える必要があります。それでlocalhost:80が機能するようにしてから、事前にレンダリングされたページにアクセスしてください。localhost:80/?_escaped_fragment_=

関連する問題