部署与运维

上一个模块中,我们分别认识前后端分离、如何进行前后端分离这两方面进行了体育赛事比分网站的前后端分离开发体系。在本模块中,我们将从部署与运维这方面进行如下三个模块的介绍。

模块划分.jpg

6 部署与运维

6.1 Docker 环境下的前后端分离部署模式

首先来介绍一下利用 docker 虚拟机的容器技术,采用分布式集群部署,达到高性能、高负载、高可用的部署方案。包括了 MySQL 集群、Redis 集群、负载均衡、双机热备等等。其大概的部署模式可见下图:

部署框架.jpg

其中:

  • 项目的持久层可以选择数据库集群,采用 MySQL 领域中成熟可靠的 PXC(Percona XtraDB Cluster)集群方案;
  • 减少数据库 IO 压力,可以通过 Redis 的 Cluster 集群实现高速缓存,一般在秒杀、抢购等业务中经常用到;
  • 实现高性能、高负载和高可用可以通过将前后端分离项目以集群的方式部署在 Docker 容器中;
  • 解决负载均衡的方案可以考虑 Haproxy 和 Nginx;
  • 组建多主机多容器分布式部署的运营平台,可以通过 Swarm 技术组件 Docker 集群。

6.2 前后端分离部署可能出现的问题

6.2.1 请求跨域

前后端分离部署之后,前端只需要 Server 端提供 API URL,这时候会产生一个问题:Ajax 跨域。这时候就不能使用一般的解决跨域的方法,比如:jsonp,iframe 信使等等,因为我们还有 POST 请求。

我们可以使用 Http Proxy 工具类,在 BrowserSync 加入中间件判断每一个请求,如果是 /api 前缀就会代理到 API Server 端,Server 端收到数据后再返回给 BrowserSync ,最后由 BrowserSync 返回给浏览器,从而解决跨域请求问题。部署时在前端 WebServer 处理端加入转发规则,Nginx 和 Apache 都支持。

6.2.2 静态资源路径

如果项目存在用户上传资源的功能,比如上传头像等。这时候的用户资源可以与后端项目放在一起,后端处理完后返回一个相对路径给前端。如果资源较多,需要一台单独的服务器,那返回资源的绝对路径即可。

6.2.3 会话问题

Web项目中最令人头疼的问题是无状态导致的会话问题,传统项目都是用 Session/Cookie,但在前后端分离集群部署模式下存在缺陷。我们可以选择主流的解决方式:Token,解决这个问题。

6.3 利用 Jenkins 实现自动化部署与持续交付

6.3.1 Jenkins 介绍

Jenkins 是一个开源软件项目,是基于Java开发的一种可拓展持续集成工具,主要用于持续、自动地构建 / 测试 / 集成软件项目以及监控一些定时执行的任务。其前身是 Hudson,它可以方便以下人员:

  • 开发人员:写好代码,不需要自己进行源码编译、打包等工作,直接将代码分支存放在SVN、GIT 仓库即可;
  • 运维人员:减轻人工干预的错误率,同时解放运维人员繁杂的上传代码、手动备份、更新;
  • 测试人员:可以通过jenkins进行简单的代码以及网站测试。

6.3.2 持续集成

持续集成(Continuous integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽快地发现集成错误。一个标准的持续集成系统能做到

111.png

部署一个 CI 系统需要的最低要求是,一个可获取的源代码的仓库,一个包含构建脚本的项目。下图概括了CI系统的基本结构:

222.png

该系统的各个组成部分是按如下顺序来发挥作用的:

  1. 开发者检入代码到源代码仓库;
  2. CI 系统会为每一个项目创建了一个单独的工作区。当预设或请求一次新的构建时,它将把源代码仓库的源码存放到对应的工作区;
  3. CI 系统会在对应的工作区内执行构建过程;
  4. (配置如果存在)构建完成后,CI 系统会在一个新的构件中执行定义的一套测试。 完成后触发通知(Email,RSS 等等)给相关的当事人;
  5. (配置如果存在)如果构建成功,这个构件会被打包并转移到一个部署目标(如服务器)或存储为软件仓库中的一个新版本。软件仓库可以是 CI 系统的一部分,也可以是一个外部的仓库,诸如一个文件服务器或者像 Java.net、 SourceForge 之类的网站;
  6. CI 系统通常会根据请求发起相应的操作,诸如即时构建、生成报告,或者检索一些构建好的构件。

而 Jenkins 就是这样一个 CI 系统。

在本模块中,我们分别从部署模式、部署问题、自动化部署三个部分介绍了如何进行网站部署与运维。到此我们的《从零开始设计和搭建你的体育赛事比分网站》这一系列就结束啦。本系列从以下六个部分介绍了一个网站项目从设计到搭建的完整过程:

  • 项目构思
  • 需求整理
  • 原型与架构设计
  • 建表优化
  • 前后端分离
  • 部署与运维

笔者没有选择过多的从代码方面上讲解网站的搭建,而使从一个宏观的角度去介绍整个流程,让大家能最直观的感受到一个网站是如何设计与搭建的,如果大家脑海里还没有形成一个网站搭建后的样子,我在这里可以举个相似的��,大家可以以这个为模板进行网站的设计和搭建哦。