本文的作者是刘欢,其导师为王小兵副教授(西安电子科技大学)和沈嘉琳高工(企业导师)。该研究由西安电子科技大学计算机科学与技术学院完成,并于2021年9月提交,作为工程硕士学位论文。
随着国内互联网的快速发展和网络购物的普及,消费者对购物平台的体验要求越来越高,同时平台面临的高并发访问量也对系统架构提出了更高的要求。传统的单体架构(monolithic architecture)在应对高并发访问时,通常采用分布式加集群的方式进行扩展,但随着线上消费的爆炸式增长,传统扩展方式逐渐暴露出瓶颈,无法满足庞大的消费需求。
微服务架构(microservice architecture)通过将单一应用划分为多个独立的微服务,每个微服务按照业务逻辑划分,独立开发和部署,具有更高的灵活性和扩展性。本文旨在基于微服务架构设计并实现一个商城购物系统,以缓解高并发访问压力,提升系统的性能和用户体验。
本文的研究流程分为以下几个步骤:
需求分析:针对在线购物的不同场景进行需求分析,使用UML用例图进行系统建模,将系统核心设计为6个微服务:商品微服务、检索微服务、用户微服务、购物车微服务、订单微服务和秒杀微服务。
总体架构设计:引入Nginx反向代理和Gateway网关,实现页面请求的负载均衡与转发。微服务功能设计通过流程图梳理关键业务逻辑,并确定技术栈。
系统实现:基于Redis缓存、Elasticsearch搜索引擎、Spring Session框架、分布式事务和分布式锁等技术实现系统的业务功能。通过序列图分析对象之间的交互及消息的时序传递,通过类图展示实现细节。
系统测试:使用Postman等工具模拟前端请求进行功能测试,使用JMeter等工具模拟高并发访问进行非功能测试。测试结果表明,基于微服务架构的商城购物系统在高并发和分布式开发上具有显著优势,系统灵活性和扩展性更强。
系统架构:成功设计并实现了一个基于微服务架构的商城购物系统,系统分为6个核心微服务,每个微服务独立运行,具备高内聚低耦合的特性。
性能测试:通过功能测试和非功能测试,验证了系统在高并发访问下的稳定性和性能。与传统的单体架构系统相比,微服务架构系统在高并发访问和分布式开发方面表现更优。
技术栈:系统采用了Spring Cloud和Spring Cloud Alibaba微服务框架,结合Redis缓存、Elasticsearch搜索引擎等技术,确保了系统的高效运行和快速响应。
本文的研究具有重要的科学价值和应用价值: - 科学价值:通过微服务架构的设计与实现,验证了微服务在高并发、分布式系统中的优势,为后续的电商系统架构设计提供了理论依据和实践参考。 - 应用价值:基于微服务架构的商城购物系统能够有效应对高并发访问,提升系统的灵活性和扩展性,为电商平台的开发和优化提供了可行的解决方案。
创新性架构设计:本文采用微服务架构,将系统划分为多个独立的微服务,每个微服务独立开发和部署,显著提升了系统的灵活性和扩展性。
高性能技术栈:系统结合了Redis缓存、Elasticsearch搜索引擎、分布式事务等技术,确保了系统在高并发访问下的高性能和稳定性。
全面的测试验证:通过功能测试和非功能测试,验证了系统在高并发访问下的性能表现,证明了微服务架构在电商系统中的优势。
本文还详细介绍了系统的数据库设计、技术栈选择以及具体的实现细节,为后续的研究者和开发者提供了丰富的参考资料。此外,本文还通过大量的图表(如UML用例图、序列图、类图等)展示了系统的设计思路和实现过程,具有较强的可读性和可操作性。
本文通过基于微服务架构的商城购物系统的设计与实现,展示了微服务架构在高并发、分布式系统中的优势。研究不仅为电商系统的架构设计提供了新的思路,也为后续的微服务架构研究提供了实践参考。