大型门户网站架构服务部署研究说明

2024-03-16 11:50

本文主要是介绍大型门户网站架构服务部署研究说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

笔者经常被朋友问起,该如何设计一个大型的门户网站架构。目前中小型网站,由于数据量相对来说比较少,特别是普通的企业网站,几乎没有什么人访问,因此,大部分都是单机版的服务架构,即:前台页面程序、后台服务程序、数据库都放在同一台服务器上。顶多也就是把数据库放到同局域网的另一台服务器而已。这是目前绝大部分网站的部署方法。 
这样的部署,给后期带来的问题是很多的。当服务程序死掉,那么整个网站就无法访问了。前台web程序的压力和后台服务程序的压力同在一台服务器上。很容易造成cpu、内存过于繁忙而导致运行效率低下。如果有上万人访问,这样的架构跑起来真是有些力不从心了。 
虽然很多程序语言都已经提供了分布式业务处理的类,而且功能也非常的强大。但是操作起来过于复杂,很多个性化的需求都不能得到高效率的解决。很多功能使用起来也过于牵强。安全性问题由于其接口的透明性而变得比较脆弱(当然高手另当别论了)。 
现在把我参与携购网(http://www.xiegoo.com)这个系统的开发来详细讲解下其部署。目前都流行把网站页面、服务程序、数据完全独立开来,这样的好处就不再累赘的讲述了。携购网的结构层我们可以分为以下几个部分: 
1. 页面展示层 
2. 前台数据处理层 
3. 前台协议处理层 
4. 前台数据传输层 

5.后台数据传输层 
6. 后台协议处理层 
7. 后台数据处理层 
8. 后台数据缓存层 
9. 数据库 
上面从宏观上可以看到,主要分成前台、后台。前台需要数据的时候,向后台发起操作协议。数据的传输是通过SOCKET 链接来完成的。关键的问题就是前台后台之间的协议。只有通过先前大家约定好的协议,后台才能知道前台需要的是什么样的操作。协议是前台与后台服务程序交互的基础。 
协议可以有多种格式来定义:典型的有数据流格式、XML格式等。 
数据流格式:如中国联通短信网关接口协议SGIP,就是约定好长度。比如前8个字节表示的数据的长度,紧跟着的10个字节表示企业的ID号等。 
数据流格式的好处是,传输的数据少。冗余数据可以最小。缺点是:因为数据流的可读性非常差,所有一旦运行中出现错误时要找到问题的所在比较麻烦些。另外,由于各种编程语言在变量定义上存在差别,所以,如果使用结构体或者实体类的数据流的传送方法,可移植性也比较差。这种方法一般用于速度要求非常高的系统下,如果游戏系统等。 

  XML格式协议,这里我们特别强调这种协议格式,携购网使用的就是XML格式协议的传送。相对于数据流格式的传送,这种方法有很多的优点。虽然在传送的过程中增加了比较多的冗余数据,但是XML的可读性非常高,可扩张性也非常高。前台程序和后台程序可以使用完全不同的程序语言。只要该程序语言支持XML的读写,就可以与后台服务程序进行交互。因此,XML格式的协议通用性非常好。如果系统对速度要求不是非常苛刻的,建议使用该格式协议。具体的架构示意图如下:

  

图一 架构部署示意图 

注意: 
黄底色的区域做为一个整体不可分割,必须放在同一台服务器上,其他的就可以任意的放。建议放在同一段IP的局域网内,这样访问的速度可以更快。 
当一个用户访问页面的时候,整个流程是这样走的:

  1. 当用户访问某个页面(我们假设这个页面不是已经生成好的静态页面,即:该页面需要访问数据库操作)。
  2. 页面展示层将调用本地“前台业务处理程序”,告知需要具体什么样的操作。
  3. 前台业务处理程序将用户的需求分解成对应的数据实体操作。同时将其交给协议解析层。
  4. 这里的协议解析层不仅仅是一个解析的过程,当该层得知需要从服务器获取数据时,它会将“业务处理层”的操作请求,转换成后台可以认识的XML格式协议。如果XML数据需要加密处理,那么在该层就将其加密处理。同时将其转交给“数据传送层”。
  5. 数据传输层接收到需要传送数据的命令后,它会从SOCKET链接缓存池里找到当前空闲的链接,进行与服务器之间的对接。这个过程中,数据传输层判断如果有多个后台服务程序可以供选择的时候,它会根据繁忙程度,找到最为空闲的一个服务进行传输。也就是说,数据传输层,先找到要传输的服务器地址。然后再找到与之对应的SOCKET链接缓存池里找最空的链接。
  6. 后台服务程序的“数据传送层”接收到前台发来的数据后,将其转交给协议解析层。
  7. “后台协议解析层”判断如果数据经过了加密处理,那么先对其进行解密处理,同时,将接收到的数据解析、转换后,提交给对应的后台业务处理程序,进行处理。比如说查询用户数据,那么就直接会定位到业务处理程序的用户查询的操作入口。
  8. 后台业务处理程序调用数据缓存。如果要查询的数据在缓存里已经存在,那么直接从缓存里返回需要的数据。如果没有则需要从数据库里查找。

  以上是从前台调用到后台的整个单向流程。当需要的数据,或者需要的操作已经完成时,程序到这里并不是停止了。后台需要将查询到或者操作后的结构返回给前台。那么需要返回操作。直到前台展示页面把最终的数据展示给客户为止。 
看上去整个流程非常复杂,有很多朋友会问如果这样的架构速度上怎么样?那么你可以去访问下携购网(http://www.xiegoo.com)试试看,总整理来说,携购网的速度已经是比较理想的了。 
这样的架构如果单从小访问量来看,是看不出该构架的优点,因为目前传统的做法是直接访问数据库,在访问速度上看,还是相当可以的,但是如果有几万,几十万用户访问的时候,那怎么办呢?直接访问数据库,或者是单机版的架构我看只能是老牛推破车了呵呵。 
接下来,我们来分析下当访问量非常大的时候,该架构如果应对?大家可以看到页面展示层,只接受用户的访问请求,所以无论从SOCKET连接压力,还是业务处理压力都是非常小的。因此,我们在这里暂时不考虑该层的减压方案。 
压力最大的部分就是业务处理部分和数据库部分。因为我们的架构是分布式处理的,所以当你的程序写的不是非常好的情况下(当然不能直接影响到数据库的死锁等等),只要不断的增加服务器,就可以解决不断增加的用户访问量。数据库部分的优化,我相信很多朋友比我更加熟悉,有太多的数据库优化方案,大家可以去网上找找。 
如果你的用户访问量真的非常大,那么软、硬件一起来吧,加上均衡处理机,再加上我们这套架构,相信已经能满足你的需求了。 
很多朋友会说,前面讲的那么理论化,听的云里雾里,能不能讲点具体的,那下面我主要讲解下最关键的XML协议部分吧: 
前台客户端:

	<? XML version=”1.0” encoding=”UTF-8”?>
<params>
<busi> user.center</busi>
<oper> user.query</oper>
<queryType>id </queryType>
<queryCondition>106</queryCondition>
<sort>
<key/>根据某个关键字排序
<direction/> 升序还是降序desc or asc
</sort>
<queryState>   //分页参数
<pageCnt></pageCnt> //每页显示的记录条数
<pageNum></pageNum>  //当前的页码
</queryState>
</params>

后台处理完毕后,返回结构协议:
	<? XML version=”1.0”  encoding=”UTF-8”?>
<result>
<success/>
<msg/>
<queryState>
<pageCnt/>
<pageNum/>
<totalRec/>   //总共查询到的记录数
<curPageCnt/> //当前页码上的记录数
<totalPage/>  //总共分几页
</queryState>
<itemList>
<item>
<id>
<name/>
</item>
……
</itemList>
</result>

上面两个协议的操作是:查询ID=106的用户的信息。 
当然,我们的协议不希望明文给人家SOCKET获取后破解,那么你可以对你的XML数据加密吧。具体的加密方法到网上找找,太多了。但是不要用不可逆的加密方法,否则请求发过去,后台服务程序要发火了。 
XML协议可以做很多事情,并不仅局限于发送文本命令,类似于文件上传,下载,等等你都可以通过XML协议的命令来完成。 携购独立网店系统( http://www.shopxg.com)上的所有上传,下载就是这样,全部是通过自己的协议格式完成的。 

好了,讲了这么多不知道大家有没有理解,再认认真真,仔仔细细的看几遍架构图,相信你会明白起来的,另外大家也可以思考下,这样的部署,如何解决南北互通的问题?

转载至: http://www.qqgb.com/Program/VC/VCZH/Program_254800.html

转载于:https://www.cnblogs.com/EasyData/archive/2009/06/26/1511679.html

这篇关于大型门户网站架构服务部署研究说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/815408

相关文章

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

k8s部署MongDB全过程

《k8s部署MongDB全过程》文章介绍了如何在Kubernetes集群中部署MongoDB,包括环境准备、创建Secret、创建服务和Deployment,并通过Robo3T工具测试连接... 目录一、环境准备1.1 环境说明1.2 创建 namespace1.3 创建mongdb账号/密码二、创建Sec

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Python项目打包部署到服务器的实现

《Python项目打包部署到服务器的实现》本文主要介绍了PyCharm和Ubuntu服务器部署Python项目,包括打包、上传、安装和设置自启动服务的步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录一、准备工作二、项目打包三、部署到服务器四、设置服务自启动一、准备工作开发环境:本文以PyChar