既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
+ - [1)比较大的差别](#1_81)
- [2)小的差别](#2_115)
C/S和B/S架构
一、C/S(Client Server)两层架构
1、C/S架构背景:
C/S架构(即客户端/服务器模式)是一种比较早的软件架构,主要应用于局域网内。C/S结构是一种软件系统体系结构,这种结构是将需要处理的业务合理地分配到客户端和服务器端,这样可以大大降低通信成本,但是升级维护相对困难。比如我们手机中安装的微信、qq、王者荣耀等应用程序就是C/S结构。
2、两层架构:
C/S架构分为客户机和服务器两层:第一层是在客户机系统上结合了表示与业务逻辑,第二层是通过网络结合了数据库服务器。简单的说就是第一层是用户表示层,第二层是数据库层。
- 第一层:客户端——表示层(界面层与逻辑层)
- 第二层:服务器模式——数据库层
3、C/S架构流程:
客户机——经过(Request)请求——服务器(即数据库)——数据库根据客户机的请求——进一步(Response)响应回去给客户机。
4、C/S架构的优点:
- C/S架构的界面和操作可以很丰富。(客户端操作界面可以随意排列,满足客户的需要)
- 安全性能可以很容易保证。(因为只有两层的传输,而不是中间有很多层)
- 由于只有一层交互,因此响应速度较快。(直接相连,中间没有什么阻隔或岔路,比如QQ,每天那么多人在线,也不觉得慢)
5、C/S架构的缺点:
- 适用面窄,通常用于局域网中。
- 用户群固定。由于程序需要安装才可使用,因此不适合面向一些不可知的用户。
- 维护成本高,发生一次升级,则所有客户端的程序都需要改变。
二、B/S(Browser Server)三层架构
1、B/S架构背景:
B/S架构(即浏览器/服务器模式)是C/S架构的一种改进,可以说属于三层C/S架构。B/S结构是随着互联网的发展,web出现后兴起的一种网络结构模式。这种模式统一了客户端,让核心的业务处理在服务端完成。节约了开发成本,维护和升级方式更简单,客户端是浏览器,基本不需要维护,只需要维护升级服务器端就可以。在手机或电脑上用浏览器上百度搜索、看新闻等就是在使用“B/S”结构进行数据交互。
2、三层架构:
- 第一层:浏览器——表现层,主要完成用户和后台的交互及最终查询结果的输出功能;
- 第二层:WEB服务器——逻辑层,主要是利用服务器完成客户端的应用逻辑功能;
- 第三层:数据库服务器——数据层,主要是接受客户端请求后独立进行各种运算。
3、B/S架构的三种形式:
第一种:客户端—服务器—数据库(常用模式)
(1)客户端向服务器发起Http请求;
(2)服务器中的web服务层能够处理Http请求;
(3)服务器中的应用层部分调用业务逻辑,调用业务逻辑上的方法;
(4)如果有必要,服务器会和数据库进行数据交换. 然后将模版+数据渲染成最终的Html, 返送给客户端。
第二种:客户端—Web服务器—应用服务器—数据库
类似于第一种方法,只是将web服务和应用服务解耦;
(1)客户端向web服务器发起Http请求;
(2)web服务能够处理Http请求,并且调用应用服务器暴露在外的RESTFUL接口;
(3)应用服务器的RESTFUL接口被调用,会执行对应的暴露方法.如果有必要和数据库进行数据交互,应用服务器会和数据库进行交互后,将json数据返回给web服务器;
(4)web服务器将模版+数据组合渲染成html返回给客户端。
第三种:客户端-负载均衡器(Nginx)-中间服务器(Node)-应用服务器-数据库
这种模式一般用在有大量的用户,高并发的应用中;
(1)整正暴露在外的不是真正web服务器的地址,而是负载均衡器器的地址;
(2)客户向负载均衡器发起Http请求;
(3)负载均衡器能够将客户端的Http请求均匀的转发给Node服务器集群;
(4)Node服务器接收到Http请求之后,能够对其进行解析,并且能够调用应用服务器暴露在外的RESTFUL接口;
(5)应用服务器的RESTFUL接口被调用,会执行对应的暴露方法.如果有必要和数据库进行数据交互,应用服务器会和数据库进行交互后,将json数据返回给Node;
(6)Node层将模版+数据组合渲染成html返回反向代理服务器;
(7)反向代理服务器将对应html返回给客户端。
Nginx的优点有:
1、它能够承受、高并发的大量的请求,然后将这些请求均匀的转发给内部的服务器,分摊压力.
2、反向代理能够解决跨域引起的问题,因为Nginx,Node,应用服务器,数据库都处于内网段中。
3、Nginx非常擅长处理静态资源(img,css,js,video),所以也经常作为静态资源服务器,也就是我们平时所说的CDN。
比如:前一个用户访问index.html, 经过Nginx-Node-应用服务器-数据库链路之后,Nginx会把index.html返回给用户,并且会把index.html缓存在Nginx上,
下一个用户再想请求index.html的时候,请求Nginx服务器,Nginx发现有index.html的缓存,于是就不用去请求Node层了,会直接将缓存的页面(如果没过期的话)返回给用户。
4、B/S常用架构流程:
客户机浏览器——经过Http请求——Web服务器——经过查询——数据库服务器——响应查询后返回结果——Web服务器——再经过Http响应——返回给客户机浏览器。
5、B/S架构的优点:
- 客户端无需安装,有Web浏览器即可。
- BS架构可以直接放在广域网上,通过一定的权限控制实现多客户访问的目的,交互性较强。
- BS架构无需升级多个客户端,升级服务器即可,可以随时更新版本。
6、B/S架构的缺点:
- 在跨浏览器上,BS架构不尽如人意。
- 表现要达到CS程序的程度需要花费不少精力。
- 在速度和安全性上需要花费巨大的设计成本,这是BS架构的最大问题。
- 客户端服务器端的交互是请求——响应模式,通常需要刷新页面,这并不是客户乐意看到的。(在Ajax流行后此问题得到了一定程度的缓解)
三、C/S与B/S的结构区别
1)比较大的差别
1、数据交互方式
- C/S是两层架构,由客户端和数据库服务器组成,客户端跟服务端进行数据交互,数据传输采用Socket协议。
- B/S是三层架构,由浏览器,WEB服务器和数据库服务器组成,浏览器跟服务器进行数据交互,数据传输采用HTTP协议。
2、逻辑事务处理
- C/S架构合理地让客户端和服务器承担一部分逻辑事务处理,使得服务器的负担减轻了,而且客户端也能进行一些数据处理和存储的功能。
- B/S架构的浏览器就是它的客户端,可是这个客户端只能进行一些简单的输入输出和信息发布共享的功能,主要的逻辑事务处理还是要靠服务器,所以服务器的负担很重。
3、工作原理
- C/S架构是客户端和服务器直接相连,实现点对点的通信,
- B/S是浏览器通过WEB服务器向数据库服务器发送数据请求,实现多对多的通信。
4、响应速度
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新