欢迎光临网络推广公司网站,这里提供有教程教您进行企业销售等服务。

网络推广网站

为你提供各种类型的目标客户产品,我们可以在B2B平台上开设商店并发布信息。

互联网三高架构:高并发、高性能、高可用

作者:jcmp      发布时间:2021-04-23      浏览量:0
前端架构浏览器优化技术:合理布局,页面缓

前端架构

浏览器优化技术:合理布局,页面缓存,减少http请求数,页面压缩,减少 cookie 传输。 1)CDN CDN的基本原理是广泛采用各种缓存服务器,将这些缓存服务器分布到用户访问相对集中的地区或网络中,在用户访问网站时,利用全局负载技术将用户的访问指向距离最近的工作正常的缓存服务器上,由缓存服务器直接响应用户请求。

2)DNS负载均衡 3)动静分离,静态资源独立部署,动态图片独立提供服务。

应用层架构

1)业务拆分 2)负载均衡 3)虚拟化服务器、容器化 4)无状态(以及分布式 Session) 分布式Session有如下几种实现方式。

1.Session复制机制

在支持Session复制的Web服务器上,通过修改Web服务器的配置,可以实现将Session同步到其它Web服务器上,达到每个Web服务器上都保存一致的Session。

优点:代码上不需要做支持和修改。

缺点:需要依赖支持的Web服务器,一旦更换成不支持的Web服务器就不能使用了,在数据量很大的情况下不仅占用网络资源,而且会导致延迟。

适用场景:只适用于Web服务器比较少且Session数据量少的情况。

可用方案:开源方案tomcat-redis-session-manager,暂不支持Tomcat8。

2.Session粘滞机制

将用户的每次请求都通过某种方法强制分发到某一个Web服务器上,只要这个Web服务器上存储了对应Session数据,就可以实现会话跟踪。

优点:使用简单,没有额外开销。

缺点:一旦某个Web服务器重启或宕机,相对应的Session数据将会丢失,而且需要依赖负载均衡机制。

适用场景:对稳定性要求不是很高的业务情景。

3.Session集中管理机制

在单独的服务器或服务器集群上使用缓存技术,如Redis存储Session数据,集中管理所有的Session,所有的Web服务器都从这个存储介质中存取对应的Session,实现Session共享。

优点:可靠性高,减少Web服务器的资源开销。

缺点:实现上有些复杂,配置较多。

适用场景:Web服务器较多、要求高可用性的情况。

可用方案:开源方案Spring Session,也可以自己实现,主要是重写HttpServletRequestWrapper中的getSession方法,博主也动手写了一个,github搜索joincat用户,然后自取。

4.基于Cookie管理机制

这种方式每次发起请求的时候都需要将Session数据放到Cookie中传递给服务端。

优点:不需要依赖额外外部存储,不需要额外配置。

缺点:不安全,易被盗取或篡改;Cookie数量和长度有限制,需要消耗更多网络带宽。

适用场景:数据不重要、不敏感且数据量小的情况。

最后的总结

以上四种方式,相对来说,Session集中管理更加可靠,使用也是最多的。

5)分布式缓存 分布式缓存的典型应用场景可分为以下几类:

异步、事件驱动架构、消息队列 EDA是一种以事件为媒介,实现组件或服务之间最大松耦合的方式。传统面向接口编程是以接口为媒介,实现调用接口者和接口实现者之间的解耦,但是这种解耦程度不是很高,如果接口发生变化,双方代码都需要变动,而事件驱动则是调用者和被调用者互相不知道对方,两者只和中间消息队列耦合。

多线程 动态页面静态化 我们只需要编写这么一个HttpModule就可以了,当用户第一次请求asp处理时,我们可以在ihttpmodule中拦截到这个请求,然后获取到这次请求应该返回的html代码,然后我们返回这些html给用户,并保存刚才我们获取到的html到文件内,当用户下次请求时,我们只需要直接返回我们已经保存的html文件即可。

服务层架构

1)分布式微服务(分级管理,超时设置,异步调用,服务降级,幂等性设计。) 同应用层架构。

存储层架构

1)DFS(分布式文件存储) 2)路由数据库 3)No SQL 数据库 4)数据同步 5)数据冗余。

安全架构

1)Web攻击(XSS、Sql Injection) 2)数据加密 3)密钥管理 4)发布、运维。

自动化测试与发布

1)灰度发布 2)浏览器数据采集 3)服务器业务数据采集 4)服务器性能数据采集 5)系统监控 6)系统报警 7)机房(散热、省电、定制服务器)。