Prerender预渲染优化SEO
单页面应用的主要内容都依赖于JS的执行,当其首页面下载下来的时候,其实不是完整的页面,而是HTML + JS文件,浏览器提供执行环境于是页面被渲染了出来。用户在访问的时候体验会很好,但是对于搜索引擎的爬虫就不太友善了,因为他们不能执行JS,这时候Prerender就派上用场了,它可以帮忙把页面渲染完成之后再返回给爬虫工具,我们的页面也就能被解析到了。最近我尝试搭建了基于本地的Prerender + NGINX的预渲染服务,希望可以帮到大家。
前置条件
由于本地的Prerender服务需要有NodeJs环境支持,如果之前服务器环境没有NodeJs需要先进行安装,可参考官网。
安装Prerender
此处我们假定安装目录在 /opt/ 下
1 2 3 4 5 6 7 8 9 10 |
cd /opt git clone https://github.com/prerender/prerender.git cd prerender # Phantomjs 官方的下载地址会超时,此处重新指定其下载地址为淘宝镜像 export PHANTOMJS_CDNURL=https://npm.taobao.org/mirrors/phantomjs npm install # 启动Server.js, 默认监听3000端口 node server.js |
可以通过curl进行测试,看看返回的内容是不是解析后的内容
1 2 |
# 如果按照成功,通过3000端口访问后的页面内容是已经解析过的 curl http://localhost:3000/http://hostname.com/webpath |
配置NGINX
我们假设项目的访问路径为 http://hostname.com/webpath/anything, 将所有/webpath/*的请求当做项目的入口地址。参考官方配置
我们只需要针对搜索引擎的访问进行Prerender预渲染,正常的浏览器访问我们避免通过Prerender进行渲染
10 11 12 13 14 15 16 17 18 19 20 21 22 |
location^~ /webpath/ { set $prerender 0; if ($http_user_agent ~* "baiduspider|twitterbot|facebookexternalhit|rogerbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") { set $prerender 1; } # 谷歌推荐的配置方式 if ($args ~ "_escaped_fragment_") { set $prerender 1; } if ($prerender = 1) { # 官方推荐通过$prerender变量来进行跳转来解决NGINX缓存 set $prerender "127.0.0.1:3000"; rewrite .* /$scheme://$host$request_uri? break; proxy_pass http://$prerender; } # 此处,我们假设主页面html为 /index.html try_files $uri$args /index.html; } |
在上面的NGINX配置中,我们针对请求参数包括 _escaped_fragment_ 也启用了Prerender服务,官方说明表示谷歌会通过这种方式来抓取单页面应用。而我们也可以借助这个特点很方便地测试配置是否正确:
1 2 |
# 不再需要直接访问 localhost:3000的地址了 curl http://hostname.com/webpath/anything?_escaped_fragment_= |
在配置NGINX以前,以上返回的只是index.html的内容, 如果配置成功则会返回解析后的内容。
将Prerender加入守护进程
上面的功能虽然能运行起来了,但是Prerender服务是依赖于SSH终端的,如果这个终端被关闭,那么服务也就被关闭了,为此我们需要将Prerender加入守护进程。
我直接使用了Git上的一个Prerender守护进程模板,并将其配置成我的环境,如下:
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 21 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 |
#!/bin/sh # # chkconfig: 35 99 99 # description: prerender.js server for the given user # . /etc/rc.d/init.d/functions APPNAME="Prerender" # 用来运行Prerender服务的用户 USER="<user that runs prerender>" # Node命令的路径,此处我直接配置为"node",因为node已经加入全局变量 DAEMON="node" # Prerender的安装目录,即是我们拷贝下来的Prerender文件夹目录,此处为 /opt/prerender ROOT_DIR="<path to prerender>" SCRIPT="$(basename $0)" PIDFILE="/var/run/$SCRIPT.pid" SERVER="$ROOT_DIR/server.js" LOG_FILE="/var/log/prerender.log" SHUTDOWN_WAIT=20 app_pid() { echo `ps -aefw | grep "$DAEMON $SERVER" | grep -v " grep " | awk '{print $2}'` } do_start() { echo -n $"Starting $SERVER: " pid=$(app_pid) if [ -n "$pid" ] then echo "$APPNAME is already running (pid: $pid)" else if [ ! -w $LOG_FILE ] then if [ ! -e $LOG_FILE ] then touch $LOG_FILE fi chown $USER $LOG_FILE fi echo "$APPNAME is not running - starting it up!" runuser --shell=/bin/bash -l "$USER" -c "$DAEMON $SERVER >> $LOG_FILE 2>&1 &" pid=$(app_pid) echo $pid > ${PIDFILE} do_status RETVAL=$? echo [ $RETVAL -eq 0 ] fi return 0 } do_wait() { echo "Waiting for process to exit"; pid=$(app_pid) if [ -n "$pid" ] then let kwait=$SHUTDOWN_WAIT count=0; until [ `ps -p $pid | grep -c $pid` = '0' ] || [ $count -gt $kwait ] do echo -n -e "\nwaiting for processes to exit"; sleep 1 let count=$count+1; done fi return 0 } do_stop() { echo -n $"Stopping $APPNAME : " pid=`ps -aefw | grep "$DAEMON $SERVER" | grep -v " grep " | awk '{print $2}'` kill -9 $pid > /dev/null 2>&1 && echo_success || echo_failure if [ -f ${PIDFILE} ]; then rm ${PIDFILE} fi RETVAL=$? echo [ $RETVAL -eq 0 ] } do_status() { pid=$(app_pid) if [ -n "$pid" ] then echo -n "$APPNAME is running (pid: $pid)" echo_success else echo -n "$APPNAME is not running" echo_failure fi echo return 0 } case "$1" in start) do_start ;; stop) do_stop ;; status) do_status ;; restart) do_stop do_wait do_start ;; *) echo "Usage: $0 {start|stop|restart|status}" RETVAL=1 esac exit $RETVAL |
将此文件命名为 prerender, 并拷贝至 /etc/init.d/
目录下。然后我们重新载入脚本:
1 2 3 4 5 6 7 8 |
# 服务新增文件可执行权限 chmod +x /etc/init.d/prerender # 重新载入systemctl systemctl daemon-reload # 启动 service prerender start |
后续,我们可以通过 service prerender start|stop|restart
来起停服务,同时Prerender也会随机启动。
http://codingfishman.github.io/2016/05/06/prerender%E9%A2%84%E6%B8%B2%E6%9F%93%E4%BC%98%E5%8C%96SEO/
Prerender预渲染优化SEO相关推荐
- vue项目使用预渲染 进行seo优化
vue项目使用预渲染 进行seo优化 vue进行seo优化的两个方法 1.预渲染*** 针对项目其中几个页面的seo,标题不能通过接口数据动态渲染 情况使用 使用以下两个插件进行预渲染seo优化: n ...
- vue使用prerender预渲染配合vue-meta实现单页面实现SEO优化
公司项目在已在开发完成的情况下通知需要做SEO优化.因为项目使用的是vue做的单页面应用,顿时人都不好了,只好网上搜罗出来一些配置(其实是另一个带我的老大哥他做的,但是他要走了,工作交接给我, 我需要 ...
- prerender ajax,Vue Prerender.io 预渲染seo优化
前言 目前 Vue单页面应用在前端界混的风生水起,它的开发思想使得我们能真正做到前后端分离.解耦.单页面应用使用浏览器动态解析JS,呈现出最终的页面,用户体验比较好,网站性能也提高不少.但网络爬虫并不 ...
- prerender html5,HTML5 VUE单页应用 SEO 优化之 预渲染(prerender-spa-plugin)
前言:当前 SPA 架构流行的趋势如日中天,前后端分离的业务模式已经成为互联网开发的主流方式,但是 单页面 应用始终存在一个痛点,那就是 SEO, 对于那些需要推广,希望能在百度搜索时排名靠前的网站而 ...
- 构建时预渲染:网页首帧优化实践
前言 自JavaScript诞生以来,前端技术发展非常迅速.移动端白屏优化是前端界面体验的一个重要优化方向,Web 前端诞生了 SSR .CSR.预渲染等技术.在美团支付的前端技术体系里,通过预渲染提 ...
- 前端性能优化 之 首屏预渲染
本文介绍一种优化首屏访问速度的技术:前端预渲染,并封装自定义的React hook,解决预渲染中的数据初始化问题. 一.首屏速度慢的问题 如果网站页面首屏访问比较慢,应该怎么优化呢? 这要结合实际情况 ...
- vue项目利用预渲染prerender-spa-plugin处理seo --viga
vue项目利用预渲染处理seo 写在前面 什么是SEO? SEO是英文 Search Engine Optimization 的缩写,中文意思"搜索引擎优化".SEO是指在了解搜索 ...
- Vue SPA项目SEO优化之预渲染Prerender-spa-plugin
目的 由于基于Vue的SPA项目普通的爬虫无法爬取项目的静态文本的内容,通过预渲染插件prerender-spa-plugin解决vue的SPA项目的SEO问题. 可以看到项目编译后的index.ht ...
- vue的SEO优化——预渲染后路由+点击事件失效问题解决
vue是单页面框架且前后端分离,不利于seo优化.针对这一点,还是有解决办法的. 预渲染后路由+点击事件失效问题解决--近期发现 最近遇到了一个前台官网,由于时间比较紧,所以我选择了用vue框架去搭建 ...
最新文章
- Ajax异步调用Web服务的例子
- linux下查看进程占用端口和端口占用进程命令
- JMeter性能测试入门
- Server Hard drive mode
- 使用Spring Boot和React进行Bootiful开发
- 工作188:表单校验规则
- linux mysql关闭启动不了了,linux启动或关闭mysql失败的解决办法
- java encode 空格_javaWeb中URLEncoder.encode空格问题
- 线段树(Segment Tree)
- 洛谷1966 火柴排队
- (宇哥云端)互联网+
- 数学分析:函数的可积条件
- bayer raw RGB raw
- 软件设计师中级-UML建模
- 四年级计算机考试反思,四年级期中考试总结反思三篇
- javaScript jquery完美判断图片是否加载完毕
- 查看centos是多少位的方式
- 人工智能如何入门学习?前景如何
- 微信每日早安推送,快来给你女友做爱心提醒吧,自定义推送名称,企业号通知非订阅号测试号,后台python,精简无第三方网站注册、无第三方接口,无基础快速上不了手
- 大数据内功修炼到企业实战2.0
热门文章
- QT实现北斗GGA数据的自动模拟生成和解析
- 易语言学习笔记——入门篇
- 企业JUNIPER-SSG配置
- 干干!JavaScript学习路线指南,阅读本文即可
- 不甘落后,佳能挑战索尼CMOS传感器王者地位
- 指定的服务器无法,AnyShare-Unify Editor 服务器与 AnyShare 对接失败,提示错误:连接失败,指定的服务器无法访问。...
- 上位机倒出OASYS数据库方法
- m基于光纤光栅传感网接入GPON的光纤通信系统matlab性能仿真,包括解码,解封装,分接,码率恢复,解帧,拆包,译码
- DDD-CQRS的落地案例
- 未来25年看隐私计算与区块链