一、概述

  近年开发模式变化,新建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. 16)用了session会话技术

    为什么用session会话技术? 因为假如你进入后台,不可能随意进入,即使你的验证通过了,那么还需要一个变量来存一个标志,假如标志的值是yes,那么我们可以直接进入后台的首页,无需验证,但是,标志是n ...

  2. <JZOJ5941>乘

    emmm还挺妙 不过我没想到qwq 考场上瞎写的还mle了心碎 把b分两..预处理下 O1询问qwq #include<cstdio> #include<iostream> # ...

  3. 【React.js小书】动手实现 React-redux(五):Provider - 方志

    我们要把 context 相关的代码从所有业务组件中清除出去,现在的代码里面还有一个地方是被污染的.那就是 src/index.js 里面的 Index: 1234567891011121314151 ...

  4. python Django请求生命周期

    首先我们知道HTTP请求及服务端响应中传输的所有数据都是字符串. 在Django中,当我们访问一个的url时,会通过路由匹配进入相应的html网页中. Django的请求生命周期是指当用户在浏览器上输 ...

  5. MyBatis like (模糊查询)

    select * from user where user_name like concat('%',#{userName},'%'); select * from user where user_n ...

  6. 在MySql中如何定义像Java中类型的Boolean类型

    在MySql中如何定义像Java中类型的Boolean类型数据..其实,mysql中 是没有直接定义成Boolean这种数据类型.它只能定义成 tinyint(1) ;如果长度是1,tinyint(1 ...

  7. Bitstream or PCM?

    背景 提问 讨论精选 一 二 三 四 五 最后 电视上同轴输出的做法. 背景 USB通道下播放声音格式为AAC的视频文件,同轴输出设置为Auto,功放没有声音,设置成PCM,有声音. 提问 Auto/ ...

  8. Protobuf 简介及简单应用

    Protobuf 是 protocol buffers 的缩写. 根据官网的说法, protocol buffers 与平台无关, 与语言无关, 实现数据序列化的一种手段. 正如名字一样, proto ...

  9. 关于Linux文件系统

    前言 文件系统是在内核中实现,能够对存储在磁盘上的二进制数据进行有效的层次化管理的一种软件.而用户程序为了实现在磁盘上使用或者创建文件,向内核发起系统调用(实际由文件系统向内核发起的系统调用)并转换为 ...

  10. Wordpress 外网访问时不显示图片解决办法

    我的云服务器是 :windows2012R 打开命令行: 进入到mysql中 show databases; //查看你Wordpress使用的数据库是否存在 use blog; //例如你使用的数据 ...