部署与运维
上一个模块中,我们分别认识前后端分离、如何进行前后端分离这两方面进行了体育赛事比分网站的前后端分离开发体系。在本模块中,我们将从部署与运维这方面进行如下三个模块的介绍。
首先来介绍一下利用 docker 虚拟机的容器技术,采用分布式集群部署,达到高性能、高负载、高可用的部署方案。包括了 MySQL 集群、Redis 集群、负载均衡、双机热备等等。其大概的部署模式可见下图:
其中:
前后端分离部署之后,前端只需要 Server 端提供 API URL,这时候会产生一个问题:Ajax 跨域。这时候就不能使用一般的解决跨域的方法,比如:jsonp,iframe 信使等等,因为我们还有 POST 请求。
我们可以使用 Http Proxy 工具类,在 BrowserSync 加入中间件判断每一个请求,如果是 /api 前缀就会代理到 API Server 端,Server 端收到数据后再返回给 BrowserSync ,最后由 BrowserSync 返回给浏览器,从而解决跨域请求问题。部署时在前端 WebServer 处理端加入转发规则,Nginx 和 Apache 都支持。
如果项目存在用户上传资源的功能,比如上传头像等。这时候的用户资源可以与后端项目放在一起,后端处理完后返回一个相对路径给前端。如果资源较多,需要一台单独的服务器,那返回资源的绝对路径即可。
Web项目中最令人头疼的问题是无状态导致的会话问题,传统项目都是用 Session/Cookie,但在前后端分离集群部署模式下存在缺陷。我们可以选择主流的解决方式:Token,解决这个问题。
Jenkins 是一个开源软件项目,是基于Java开发的一种可拓展持续集成工具,主要用于持续、自动地构建 / 测试 / 集成软件项目以及监控一些定时执行的任务。其前身是 Hudson,它可以方便以下人员:
持续集成(Continuous integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽快地发现集成错误。一个标准的持续集成系统能做到
部署一个 CI 系统需要的最低要求是,一个可获取的源代码的仓库,一个包含构建脚本的项目。下图概括了CI系统的基本结构:
该系统的各个组成部分是按如下顺序来发挥作用的:
而 Jenkins 就是这样一个 CI 系统。
在本模块中,我们分别从部署模式、部署问题、自动化部署三个部分介绍了如何进行网站部署与运维。到此我们的《从零开始设计和搭建你的体育赛事比分网站》这一系列就结束啦。本系列从以下六个部分介绍了一个网站项目从设计到搭建的完整过程:
笔者没有选择过多的从代码方面上讲解网站的搭建,而使从一个宏观的角度去介绍整个流程,让大家能最直观的感受到一个网站是如何设计与搭建的,如果大家脑海里还没有形成一个网站搭建后的样子,我在这里可以举个相似的��,大家可以以这个为模板进行网站的设计和搭建哦。
购买咨询
购买咨询