vue项目的SEO优化,结合prerender.io怎么配置nginx让预渲染始终运行?

server {
  listen 80;
  server_name  www.edijin.net;
  access_log /data/wwwlogs/youdomain.com_nginx.log combined;
  index index.html index.htm index.php index.jsp;
  root /usr/local/apache-tomcat-7.0.82/webapps/ROOT;
  location / {
    try_files $uri @prerender;
  }
  location @prerender {
      proxy_set_header X-Prerender-Token BR9ODfIWe0KBuInh0jir;
      
      set $prerender 0;
      if ($http_user_agent ~* "baiduspider|Sogou web spider|360spider|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|svg|eot)") {
          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";
          set $prerender "127.0.0.1:3000";
          rewrite ^(.+)$ /$scheme://$host$request_uri? break;
          #rewrite .* /$scheme://$host$request_uri? break;
          proxy_pass http://$prerender;
      }
      if ($prerender = 0) {
          rewrite ^(.+)$ /index.html break;
      }
  }
 
  
}

这是我的nginx配置文件,目前是只有针对 爬虫 和 特定url 也就是$prerender = 1的时候才会启动预渲染
我想让预渲然服务始终运行达到像nuxt那样的效果,本人前端nginx配置真的头痛不知道该怎么改。。。。

阅读 3.4k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题