电商行业的模式:
B2B:企业到企业,商家到商家。代表:阿里巴巴、慧聪网。
B2C:商家到客户。代表:京东、淘宝商城(B2B2C)。
C2C:客户到客户。淘宝集市。
O2O:线上到线下。
淘淘商城的模式:
淘淘网上商城是一个综合性的B2C平台,类似京东商城、天猫商城。会员可以在商城浏览商品、下订单,以及参加各种活动。
管理员、运营可以在平台后台管理系统中管理商品、订单、会员等。
客服可以在后台管理系统中处理用户的询问以及投诉。
功能模块:
功能描述:
后台管理系统:管理商品、订单、类目、商品规格属性、用户管理以及内容发布等功能。
前台系统:用户可以在前台系统中进行注册、登录、浏览商品、首页、下单等操作。
会员系统:用户可以在该系统中查询已下的订单、收藏的商品、我的优惠券、团购等信息。
订单系统:提供下单、查询订单、修改订单状态、定时处理订单。
搜索系统:提供商品的搜索功能。
单点登录系统:为多个系统之间提供用户登录凭证以及查询登录用户的信息
2.3.1技术架构的对比
传统架构
功能模块集中在一个工程里,部署在服务器或者集群上,集群的每台服务器包含相同的代码
问题:
模块之间耦合度太高,其中一个升级其他都得升级。
开发困难,各个团队开发最后都要整合一起。
系统的扩展性差。
不能针对每个模块的需要,灵活的进行分布式部署
分布式架构:
分布式:把系统拆分成多个工程,多个工程互相协作
优点:
把模块拆分,使用接口通信,降低模块之间的耦合度。
把项目拆分成若干个子项目,不同的团队负责不同的子项目。
增加功能时只需要再增加一个子项目,调用其他系统的接口就可以。
可以灵活的进行分布式部署
缺点:
系统之间交互需要使用远程通信,接口开发增加工作量
技术选型
idea
jdk 13
win7
Spring、SpringMVC、Mybatis
svn/git(版本管理)
JSP、JSTL、jQuery、jQuery plugin、EasyUI(VUE是前端)、KindEditor(富文本编辑器)、CSS+DIV
Redis(缓存服务器)
Solr(搜索)
httpclient(调用系统服务)
Mysql
Nginx(web服务器)
工程总览
使用了面向服务的架构(Service-Oriented Architecture, SOA)
数据库
mysql作为关系型数据库,提供数据的持久化。
redis作为内存数据库,提供高性能的缓存。
服务层
taotao-rest提供商品信息,内容服务。
taotao-sso提供单点登录服务。
taotao-order提供订单服务。
taotao-search提供商品搜索服务,基于solr索引库。
交互
taotao-portal作为网站的门户,与用户交互。
微信商城之类的app也可以调用服务层的服务,完成门户的功能。
taotao-manager作为后台管理,供管理员完成对网站商品和内容的增删改查。