一、概述

  近年开发模式变化,新建Web站点采用前后端分离部署已经是大势所趋。但是,搜索引擎爬虫不会执行js脚本从后端加载数据,不利于搜索引擎对站点的收录。因此,做好SEO优化可以让各大搜索引擎更好的收录Web站点。
  本文将以我的个人博客 (CentOS7.6 Nginx环境)为例来谈一下使用Prerender为前后端分离项目做SEO优化的操作流程。

个人博客站点部署架构图

  从上面的部署架构图可以看到本站点是浏览器前端渲染的,传统的搜索引擎无法抓取到页面数据,如下图:

做SEO优化前抓取首页

二、Prerender介绍与环境安装

  Prerender采用预渲染方式解决SEO问题,可以极大的提高网页访问速度。

  Prerender是一个基于Node.js的程序,所以安装Prerender之前需要有Node.js环境。同时,由于Prerender本身并不执行js,而是使用谷歌浏览器来完成页面渲染,所以需要安装google-chrome。

1、安装google-chrome

  配置yum源,/ect/yum.repos.d/目录增加google-chrome.repo文件,并写入以下内容:

[google-chrome]
name=google-chrome
baseurl=http://dl.google.com/linux/chrome/rpm/stable/$basearch
enabled=1
gpgcheck=1
gpgkey=https://dl-ssl.google.com/linux/linux_signing_key.pub

  执行安装命令 yum -y install google-chrome-stable –nogpgcheck

  安装完后默认路径为 /opt/google/chrome

  修改/usr/bin/google-chrome文件,最后一行改为 exec -a "$0""$HERE/chrome" "$@" --user-data-dir --no-sandbox

  (注:正常情况下google是不能用root用户启动的,修改此处之后可使用root用户启动)

  检查/usr/bin目录下是否有google-chrome文件,如果没有,需要创建链接,执行命令 ln /opt/google/chrome/google-chrome/usr/bin/google-chrome

  (注:Prerender在Linux环境默认的谷歌浏览器位置/usr/bin/google-chrome)

2、安装Node.js环境

  下载nodejs地址 https://nodejs.org/en/download/

  将下载的node-v12.16.1-linux-x64.tar.xz文件上传到Linux服务器/usr/local目录

  解压命令 tar –xvf node-v12.16.1-linux-x64.tar.xz

  修改文件夹名称 mv /usr/local/node-v12.16.1-linux-x64 /usr/local/

检查nodejs是否安装成功 node –v

  安装淘宝镜像cnpm npm install-g cnpm --registry=https://registry.npm.taobao.org

  将/usr/local/nodejs/bin目录下的3个文件创建连接到/usr/local/bin/目录,如创建cnpm连接 ln -s /usr/local/nodejs/bin/cnpm /usr/local/bin/

3、安装Prerender 服务

  下载Prerender git clone https://github.com/prerender/prerender.git

  若没有安装git服务,可手动从Github下载再上传到/mnt文件夹下,再解压到当前目录下

  安装依赖包 cnpm install

  启动服务 node server.js

  (注:以守护进程方式启动服务 nohup nodeserver.js > ../logs/prerender.log 2>&1 &,避免ssh对话窗口关闭导致服务关闭)

三、SEO优化

1、Nginx配置

server {
listen 80;
server_name blog.ccyws.cn;
set$prerender_url 'http://127.0.0.1:3000';
location/ {
set $prerender 0;
if ($http_user_agent ~*"baiduspider|Googlebot|360Spider|Bingbot|Sogou Spider|Yahoo! SlurpChina|Yahoo! Slurp|twitterbot|facebookexternalhit|rogerbot|embedly|quora linkpreview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator") {
set $prerender 1;
}
if ($prerender = 1) {
proxy_pass $prerender_url;
rewrite ^(.*)$ /http://$host$1break;
}
root /mnt/blog/blog;
index index.html;
try_files $uri $uri/ /index.html;
}
}

 重启Nginx nginx –s reload

2、验证SEO优化

curl --header "User-agent:Bingbot" http://blog.ccyws.cn

做SEO优化后抓取首页

Prerender输出日志

Nginx输出日志

前后端分离项目采用Prerender的SEO优化流程的更多相关文章

  1. 前端后端分离,怎么解决SEO优化的问题呢?

    对于90%以上的互联网公司来说,前后端分离是必须要做的.目前接手的公司的一个工程,后端是PHP,用的smarty模板,开发效率和之前公司的完全分离相比,确实低不少,一方面需要前端会PHP,另一方面沟通 ...

  2. 前后端分离下的CAS跨域流程分析

    写在最前 前后端分离其实有两类: 开发阶段使用dev-server,生产阶段是打包成静态文件整个放入后端项目中. 开发阶段使用dev-server,生产阶段是打包成静态文件放入单独的静态资源服务器中, ...

  3. 分享我在前后端分离项目中Gitlab-CI的经验

    长话短说,今天分享我为前后端分离项目搭建Gitlab CI/CD流程的一些额外经验. Before Gitlab-ci是Gitlab提供的CI/CD特性,结合Gitlab简单友好的配置界面,能愉悦的在 ...

  4. 一行代码实现Vue微信支付,无需引用wexin-sdk库,前后端分离HTML微信支付,无需引用任何库

    前后端分离项目实现微信支付的流程: 1:用户点击支付 2:请求服务端获取支付参数 3:客户端通过JS调起微信支付(微信打开的网页) * 本文主要解决的是第3步,视为前两步已经完成,能正确拿到支付参数, ...

  5. (转)也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

    原文链接:http://ued.taobao.org/blog/2014/04/full-stack-development-with-nodejs/ 随着不同终端(pad/mobile/pc)的兴起 ...

  6. 也谈基于NodeJS的全栈式开发(基于NodeJS的前后端分离)

    前言 为了解决传统Web开发模式带来的各种问题,我们进行了许多尝试,但由于前/后端的物理鸿沟,尝试的方案都大同小异.痛定思痛,今天我们重新思考了“前后端”的定义,引入前端同学都熟悉的NodeJS,试图 ...

  7. 浅谈前后端分离与实践 之 nodejs 中间层服务(二)

    一.背景 书接上文,浅谈前后端分离与实践(一) 我们用mock服务器搭建起来了自己的前端数据模拟服务,前后端开发过程中只需定义好接口规范,便可以相互进行各自的开发任务.联调的时候,按照之前定义的开发规 ...

  8. dotnetcore vue+elementUI 前后端分离架二(后端篇)

    前言 最近几年前后端分离架构大行其道,而且各种框架也是层出不穷.本文通过dotnetcore +vue 来介绍 前后端分离架构实战. 涉及的技术栈 服务端技术 mysql 本项目使用mysql 作为持 ...

  9. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十五║初探SSR服务端渲染(个人博客二)

    缘起 时间真快,现在已经是这个系列教程的下半部 Vue 第 12 篇了,昨天我也简单思考了下,可能明天再来一篇,Vue 就基本告一段落了,因为什么呢,这里给大家说个题外话,当时写博文的时候,只是想给大 ...

随机推荐

  1. zoj2588-tarjan求桥/割边

    tarjan求桥,算法流程详见核心代码: void tarjan(int k){ dfn[k]=low[k]=++cnt; //fa[k]=(edge){f,0,fid}; for(int i=hea ...

  2. 体验vSphere 6之1-安装VMware ESXi 6 RC版(转载)

    体验vSphere 6之1-安装VMware ESXi 6 RC版 在2015年,各个公司都会发布一系列新的产品,例如Microsoft会发布Windows 10,VMware会发布vSphere 6 ...

  3. miracle|

    N-COUNT 奇迹;出人意料的事If you say that a good event is a miracle, you mean that it is very surprising and ...

  4. MAYA卸载/完美解决安装失败/如何彻底卸载清除干净MAYA各种残留注册表和文件的方法

    在卸载MAYA重装MAYA时发现安装失败,提示是已安装或安装失败.这是因为上一次卸载后没有清理干净,系统会误认为已经安装过了.有的同学是新装的系统也会出现安装失败的情况,这是因为C++ 或者.NET的 ...

  5. stress施压案例分析——cpu、io、mem【命令分析】

    stress施压命令分析 一.stress --cpu 1 --timeout 600  分析现象?负载为啥这么高?top命令查看用户进程消耗的cpu过高(stress进程消耗的) 分析现象,可以看出 ...

  6. dos窗口运行python文件提示找不到模块

    问题:在pycharm直接运行test_suit.py正常,通过dos窗口运行则提示找不到模块. 原因: https://blog.csdn.net/crylearner/article/detail ...

  7. SQL逻辑查询处理顺序特别提醒

    我们知道在SQL语句中,第一个被处理的子句式FROM,而不是第一出现的SELECT.这就是SQL不同于其他编程语言的最明显特征之一,以下先看一下SQL查询处理的步骤序号: (8) SELECT (9) ...

  8. JAVA9中文API百度网盘免费下载

    JAVA9中文API百度网盘免费下载: https://pan.baidu.com/s/1tvHYQA8yyAS4xUFxwWrx_Q 提取码: 6e5h

  9. 会编程的 AI + 会修 Bug 的 AI,等于什么 ?

    2017-02-25 Python开发者 (点击上方公众号,可快速关注) 关于人工智能未来的畅想,除了家庭服务机器人,快递无人机,医用机器人等等,Lucas Carlson 认为人工智能在另外一个领域 ...

  10. Linux内核初探 之 进程(三) —— 进程调度算法

    一.基本概念 抢占 Linux提供抢占式多任务,基于时间片和优先级对进程进行强制挂起 非抢占的系统需要进程自己让步(yielding) 进程类型 IO消耗型 经常处于可运行态,等待IO操作过程会阻塞 ...