随着各大互联网公司业务需求的快速增长,业务架构已经不是一个新鲜词。业务的快速发展、业务量的持续增长、业务场景的日益复杂和差异化、业务需求的不断变化,都对平台架构和系统设计的演进提出了更多的挑战和更高的要求。架构师在设计系统时要考虑到业务功能的实现,保证系统的高并发性和高可用性。
下面就带大家了解什么是高并发?什么是高性能?什么是高可用?
1、商城高并发(High Concurrency)
图片来自互联网,如有侵权联系删除
商城高并发是互联网分布式系统架构设计中必须考虑的因素之一。通常意味着通过设计,系统可以同时并行处理许多请求。高并发性的一些常用指标是响应时间、吞吐量、每秒查询数(QPS)、并发用户数等。
如何提高并发性?一方面要提升单机硬件性能(优先):比如增加32核等CPU核数、升级万兆等更好的网卡、升级SSD等更好的硬盘、扩展2T等硬盘容量、扩展128G等系统内存。另一方面,要提高单机架构的性能:比如用缓存来减少IO次数、用异步来增加单业务吞吐量、用无锁数据结构来减少响应时间。
2、商城高性能(High Performance)
图片来自互联网,如有侵权联系删除
什么是商城高性能?商城高性能意味着程序处理速度很快,占用内存小,CPU利用率低。高性能指标通常与高并发指标密切相关。要提高性能,就要提高系统的高并发能力,两者是捆绑在一起的。
在应用性能优化时,计算密集型和IO密集型还是有很大区别的,需要分开考虑。还可以增加服务器数量、内存、IO等参数,提高系统的并发和性能,但不要浪费资源。应该考虑硬件的最高利用率,以便将其最大化。
CRMEB Pro版是CRMEB研发的一款高性能私域营销电商系统,系统采用Tp6 + Swoole+redis高性能框架开发,基于异步事件驱动和协程的并行网络通信引擎,充分利用了底层的epoll / kqueue实现网络事件请求处理;通过 Swoole协程异步处理数据,高效解决了PHP高并发处理问题!
怎么样提高商城性能呢?
避免因IO阻塞导致CPU闲置,造成CPU浪费。
避免在多个线程之间添加锁来确保同步,从而导致并行系统的串行化。
避免创建、销毁和维护过多的进程和线程,导致操作系统在调度上浪费资源。
3、商城高可用(High Availability)
图片来自互联网,如有侵权联系删除
商城高可用性通常用于描述系统经过专门设计,以减少停机时间并保持其服务高度可用(始终可用)。
实现高度可用的互联网应用和服务是一项非常具有挑战性的任务。每个架构师可能对高可用性有不同的理解,对于许多架构师来说,高可用性意味着没有单点服务故障、冗余数据备份以及在架构设计中避免单点。
三高(高并发、高性能、高可用)问题是每个程序员毕生都在追求解决的问题,也是行业密切关注的问题,任何一点突破,都会给行业带来一定的影响。总之,探索永无止境,吾辈仍需努力!
标签:三高,系统,并发,高性能,高可用性,CPU,商城 From: https://blog.51cto.com/u_15723831/5754540